2013-04-14 108 views
3

如您所知,如果查詢不成功,請求返回false。隨着時間的推移,我養成了一個習慣(你應該告訴我,如果這是一個壞一個)通過執行類似Android檢查服務器響應「是」JSON

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

然而,爲了使像

$res = mysql_query(...); 

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

響應的處理效果很好的JavaScript ,在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'的'try'在Java中什麼也不做(我知道)。 – Dave

+0

如果你發佈你回來的實際json,這也會有所幫助。它看起來只是「真的」,顯然不能轉換爲數組。 –

+0

@Dave當然我在做錯誤handlin,只是編輯我的問題。 @Sam Dufel確實是這樣,但是這怎麼能像JS一樣被處理(我知道'var'在聲明時沒有特定的類型)。 –

回答

2

好了,問題是,有時返回的數據表示一個JSON對象,其他時候表示一個JSON數組。您的Android代碼在所有情況下都將數據視爲數組。你可以處理這個,但不是與您現在使用的JSON.org庫。由於您正在爲Android開發,因此您可以訪問Gson庫 - 並且可以使用它:

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

很簡單。但請注意,您應該真正使用適當的HTTP狀態代碼(50x代碼之一)指示錯誤情況,而不是僅僅依賴返回的數據。

+0

謝謝,簡單但很棒 –