Как вы знаете, запрос 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-знакомый» или не
вам нужно добавить инструкцию 'catch' для этой конкретной ошибки. «Попробуйте» без «catch» ничего не делает (что я знаю) на Java. – Dave
, если вы публикуете фактический json, который вы возвращаетесь, это также было бы полезно. Похоже, что это просто «истина», которая, очевидно, не может быть преобразована в массив. –
@ Давно, конечно, я делаю ошибку handlin, только что отредактировал мой вопрос. @Sam Dufel действительно так, но как это можно обработать, как в JS (я знаю, что при объявлении «var» не имеет определенного типа). –