web-dev-qa-db-ja.com

Android Volley error.getMessage()は空白です

だから私はPOST JSonObjectRequestを私のサーバーに作成していて、それが成功するとすべてが機能し、情報が投稿されますが、エラーがありトーストに表示しようとすると、それは表示されますこれが私のリクエストです:

private void logUserIn() {
    final String URL = Globals.BASE_URL +"/auth/login/";
    // Post params to be sent to the server
    HashMap<String, String> params = new HashMap<String, String>();
    params.put("username", username.getText().toString());
    params.put("password", password.getText().toString());

    JsonObjectRequest req = new JsonObjectRequest(URL, new JSONObject(params),
            new Response.Listener<JSONObject>() {
                @Override
                public void onResponse(JSONObject response) {
                    try {
                        Log.d("Log In User", response.toString());

                        //logged in db, changes screens
                        Intent nextScreen = new Intent(getApplicationContext(), MyProfile.class);
                        startActivity(nextScreen);
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            }, new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {
            Toast.makeText(getApplicationContext(), error.getMessage(), Toast.LENGTH_SHORT).show();
            VolleyLog.e("Error: ", error.getMessage());
        }
    });

    // add the request object to the queue to be executed
    Globals.mRequestQueue.add(req);
}

error.getMessage()は常に空白です。サーバーがエラーを返したときの私の応答(CURLを使用してテスト)は次のとおりです。

{"non_field_errors":["提供された資格情報でログインできません。" ]}

このメッセージを印刷できないようです。何が欠けていますか? POSTは機能しますが、エラー応答が空白を示しています...

14
mikebertiean

VolleyErrorオブジェクトにはnetworkResponse参照があります。そこから有用な情報を取得できるかどうかを確認してください。

@Override
public void onErrorResponse(VolleyError error) {
    if (error == null || error.networkResponse == null) {
        return;
    }

    String body;
    //get status code here
    final String statusCode = String.valueOf(error.networkResponse.statusCode);
    //get response body and parse with appropriate encoding
    try {
        body = new String(error.networkResponse.data,"UTF-8");
    } catch (UnsupportedEncodingException e) {
        // exception
    }

    //do stuff with the body...
}
38
Lazy Ninja