如您所知,如果查询不成功,则php mysql_query()
请求会返回false
。随着时间的推移,我养成了一种习惯(你应该告诉我它是不是很糟糕)来制作像
$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 :(得分:2)
好的,问题是有时你返回的数据代表一个JSON对象,有时候它代表一个JSON数组。在所有情况下,您的Android代码都将数据视为数组。您 可以 处理此问题,但不能使用您现在使用的JSON.org库。由于您正在为Android开发,因此您可以内置访问Gson库 - 您可以使用它来执行此操作:
JSONElement jsonElem = new JsonParser().parse(result);
if(jsonElem.isJsonArray()) {
// Normal data
} else {
// 'Error' data'
}
非常简单。但请注意,您应该使用适当的HTTP状态代码(50x代码之一)来指示错误情况,而不是仅仅依赖于返回的数据。
答案 1 :(得分:0)
根据:http://www.ietf.org/rfc/rfc4627.txt 应该是“application / json”。
boolean isJSON =“application / json”.equalsIgnoreCase(entity.getContentType());