3

ご存知のように、クエリが成功しなかった場合、 phpmysql_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:ここでこの質問を見つけましたが、重複しているとは思いません。ここでは、オブジェクトが「JSON に精通している」かどうかを確認するためです。

4

2 に答える 2

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 つ) でエラー状態を示す必要があることに注意してください。

于 2013-04-14T19:21:54.473 に答える
0

によると:http ://www.ietf.org/rfc/rfc4627.txt は「application/json」でなければなりません。

boolean isJSON = "application/json".equalsIgnoreCase(entity.getContentType());

于 2013-04-14T19:27:01.963 に答える