2013-04-14 4 views
3

Как вы знаете, запрос php mysql_query() возвращает false, если запрос не увенчался успехом. Со временем, я сформировал привычку (вы должны сказать мне, если это плохой один), чтобы сделать что-то вродеAndroid проверить, если ответ сервера «есть» JSON

$res = mysql_query(...); 

if($res == false){ 
    echo json_encode("notOK"); 
}else{ 
    $return = array(); 
    // process query result into that array 
    echo json_encode($return); 
} 

Обработка ответа хорошо работает в JavaScript, делая что-то вроде

// (...) 
success : function(response){ 
    var res = JSON.parse(resonse); 
    if(res == "notOK"){ 
     // error handling 
    }else{ 
     // proceed 
    } 
} 
// (...) 

Однако , в Android это, похоже, не работает. Мой стандартный процесс для обработки запроса на сервер является

HttpClient client = new DefaultHttpClient(); 
HttpGet get = new HttpGet(url); 
HttpResponse response; 
Vector<JSONObject> vector = new Vector<JSONObject>(); 

try{ 
    response = client.execute(get);   
    HttpEntity entity = response.getEntity(); 

    if(entity != null){ 
     InputStream in = entity.getContent(); 
     String result = convertStreamtoString(in); 

     JSONArray resultArray = new JSONArray(result); 

     int len = resultArray.length(); 

     for(int i=0; i<len; i++){ 
      vector.add(resultArray.getJSONObject(i)); 
     } 

     in.close(); 
    } 
} catch (//... 

Это приводит к JSONException, который читает

04-14 17:13:23.011: W/System.err(433): org.json.JSONException: Value true of type java.lang.String cannot be converted to JSONArray 
04-14 17:13:23.022: W/System.err(433): at org.json.JSON.typeMismatch(JSON.java:107) 
04-14 17:13:23.022: W/System.err(433): at org.json.JSONArray.<init>(JSONArray.java:91) 
04-14 17:13:23.022: W/System.err(433): at org.json.JSONArray.<init>(JSONArray.java:103) 
04-14 17:13:23.022: W/System.err(433): at imhotapp.schlettibusiness.rest.RestHandler.login(RestHandler.java:52) 
04-14 17:13:23.022: W/System.err(433): at imhotapp.schlettibusiness.LoginActivity.tryLogin(LoginActivity.java:48) 
04-14 17:13:23.030: W/System.err(433): at java.lang.reflect.Method.invokeNative(Native Method) 
04-14 17:13:23.030: W/System.err(433): at java.lang.reflect.Method.invoke(Method.java:507) 
04-14 17:13:23.030: W/System.err(433): at android.view.View$1.onClick(View.java:2139) 
04-14 17:13:23.030: W/System.err(433): at android.view.View.performClick(View.java:2485) 
04-14 17:13:23.030: W/System.err(433): at android.view.View$PerformClick.run(View.java:9080) 
04-14 17:13:23.030: W/System.err(433): at android.os.Handler.handleCallback(Handler.java:587) 
04-14 17:13:23.030: W/System.err(433): at android.os.Handler.dispatchMessage(Handler.java:92) 
04-14 17:13:23.030: W/System.err(433): at android.os.Looper.loop(Looper.java:123) 
04-14 17:13:23.030: W/System.err(433): at android.app.ActivityThread.main(ActivityThread.java:3683) 
04-14 17:13:23.030: W/System.err(433): at java.lang.reflect.Method.invokeNative(Native Method) 
04-14 17:13:23.030: W/System.err(433): at java.lang.reflect.Method.invoke(Method.java:507) 
04-14 17:13:23.030: W/System.err(433): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
04-14 17:13:23.030: W/System.err(433): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
04-14 17:13:23.030: W/System.err(433): at dalvik.system.NativeStart.main(Native Method) 

Есть ли способ, чтобы справиться с этим, как и в JavaScript? Я делаю что-то принципиально неправильно?

PS: Я нашел this question здесь, но я не думаю, что это дубликат, потому что здесь речь идет о проверке, является ли объект даже «JSON-знакомый» или не

+0

вам нужно добавить инструкцию 'catch' для этой конкретной ошибки. «Попробуйте» без «catch» ничего не делает (что я знаю) на Java. – Dave

+0

, если вы публикуете фактический json, который вы возвращаетесь, это также было бы полезно. Похоже, что это просто «истина», которая, очевидно, не может быть преобразована в массив. –

+0

@ Давно, конечно, я делаю ошибку handlin, только что отредактировал мой вопрос. @Sam Dufel действительно так, но как это можно обработать, как в JS (я знаю, что при объявлении «var» не имеет определенного типа). –

ответ

2

Хорошо, проблема в том, что иногда ваши возвращенные данные представляют объект JSON, а в других случаях он представляет массив JSON. Ваш Android-код обрабатывает данные как массив во всех случаях. You может обрабатывать это, но не с помощью библиотеки JSON.org, которую вы используете сейчас. Поскольку вы разрабатываете для Android вы построили в доступе к библиотеке Gson - и с его помощью вы можете сделать это:

JSONElement jsonElem = new JsonParser().parse(result); 
if(jsonElem.isJsonArray()) { 
    // Normal data 
} else { 
    // 'Error' data' 
} 

Довольно простой. Однако обратите внимание, что вы действительно должны указывать условия ошибки с соответствующим кодом статуса HTTP (один из 50x кодов), а не просто полагаться на возвращаемые данные.

+0

спасибо, просто, но отлично –