VolleyError NetworkResponse为空

时间:2016-01-31 05:57:01

标签: php android android-volley

不是Android的新手,而是Volley Library的新手。 我正在尝试将stringRequest发送到服务器(类型为POST)以更新和检索行。在那之后,我试图让Json得到回应。

php代码工作正常。已经使用html表单进行了测试。

问题: VolleyError返回null。 当尝试getMessage()时,它返回null,甚至我无法打印Networkstatus代码。

以下是stringRequest代码......

/**
 * function to verify login details in mysql db
 * */
private void checkLogin(final String vehicle_no, final String password) {
    // Tag used to cancel the request
    String tag_string_req = "req_login";

    pDialog.setMessage("Logging in ...");
    showDialog();

    StringRequest strReq = new StringRequest(Method.POST,
            AppConfig.URL_LOGIN, new Response.Listener<String>() {

        @Override
        public void onResponse(String response) {
            Log.e(TAG, "Login Response: " + response.toString());
            hideDialog();

            try {
                JSONObject jObj = new JSONObject(response);
                boolean error = jObj.getBoolean("error");

                // Check for error node in json
                if (!error) {
                    // user successfully logged in
                    // Create login session
                    session.setLogin(true);

                    // Now store the user in SQLite
                    JSONObject user = jObj.getJSONObject("user");
                    String name = user.getString("name");
                    String vehicle_no = user.getString("vehicle_no");
                    String created_at = user.getString("created_at");

                    // Inserting row in users table
                    db.addUser(name,vehicle_no, created_at);

                    // Launch main activity
                    Intent intent = new Intent(LoginActivity.this,
                            MainActivity.class);
                    startActivity(intent);
                    finish();
                } else {
                    // Error in login. Get the error message
                    String errorMsg = jObj.getString("error_msg");
                    Toast.makeText(getApplicationContext(),
                            errorMsg, Toast.LENGTH_LONG).show();
                }
            } catch (JSONException e) {
                // JSON error
                e.printStackTrace();
                Toast.makeText(getApplicationContext(), "Json error: " + e.getMessage(), Toast.LENGTH_LONG).show();
            }

        }
    }, new Response.ErrorListener() {

        @Override
        public void onErrorResponse(VolleyError error) {
            Log.e(TAG, "Login Error: " + error.getMessage());
            Log.e(TAG, "Login Error: " + error.networkResponse.statusCode);

            Toast.makeText(getApplicationContext(),
                    error.getMessage(), Toast.LENGTH_LONG).show();
            hideDialog();
        }
    }) {

        @Override
        protected Map<String, String> getParams() {
            // Posting parameters to login url
            Map<String, String> params = new HashMap<String, String>();
            params.put("vehicle_no", vehicle_no);
            params.put("password", password);

            return params;
        }

    };

    Log.d(TAG, "string req: " + strReq.toString());
    // Adding request to request queue
    AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
}

这是日志:

01-31 11:30:37.407 14868-14868/csi_research_wing.vehicle D/LoginActivity: string req: [ ] http://192.168.0.101/android_login_api/login.php 0x85adf655 NORMAL null
01-31 11:30:45.035 14868-14868/csi_research_wing.vehicle E/LoginActivity: Login Error: null
01-31 11:30:45.036 14868-14868/csi_research_wing.vehicle D/AndroidRuntime: Shutting down VM
    01-31 11:30:45.039 14868-14868/csi_research_wing.vehicle E/AndroidRuntime: FATAL EXCEPTION: main
Process: csi_research_wing.vehicle, PID: 14868
java.lang.NullPointerException: Attempt to read from field 'int com.android.volley.NetworkResponse.statusCode' on a null object reference
at csi_research_wing.vehicle.activity.LoginActivity$5.onErrorResponse(LoginActivity.java:187)
at com.android.volley.Request.deliverError(Request.java:524)
at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:101)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5292)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)

1 个答案:

答案 0 :(得分:0)

排名不支持401 事实证明,如果没有修改Google Volley代码,则无法保证error.networkResponse为非null,因为Volley中的一个错误会在BasicNetwork.java中抛出Http状态代码401(HttpStatus.SC_UNAUTHORIZED)的异常NoConnectionError(134)在设置networkResponse的值之前。

<强>变通

在这种情况下,我们的解决方案不是修复Volley代码,而是修改Web Service API以针对特定情况发送Http Error Code 403(HttpStatus.SC_FORBIDDEN)。

对于此Http状态代码,在Volley错误处理程序中,error.networkResponse的值为非null:public void onErrorResponse(VolleyError错误)。并且,error.networkResponse.httpStatusCode正确返回HttpStatus.SC_FORBIDDEN。

其他-建议

Rperryng关于扩展Request类的建议可能提供了一个解决方案,并且是一个富有创意和出色的想法。非常感谢您的详细示例。我发现我们案例的最佳解决方案是使用解决方法,因为我们很幸运能够控制Web服务API。

如果我无法在服务器上进行简单的更改,我可能会选择将Volley代码修复到BasicNetwork.java中的一个位置。