Volley onErrorResponse给出NullPointerException

时间:2013-10-31 07:47:24

标签: android nullpointerexception android-volley

我在我的Android应用程序中尝试排球库

这是我的日志

    10-31 14:30:09.277: E/AndroidRuntime(22916): java.lang.NullPointerException
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.mypackage.api.Api$2.onErrorResponse(Api.java:269)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.volley.Request.deliverError(Request.java:517)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.volley.ExecutorDelivery$ResponseDeliveryRunnable.run(ExecutorDelivery.java:101)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Handler.handleCallback(Handler.java:615)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Handler.dispatchMessage(Handler.java:92)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.os.Looper.loop(Looper.java:137)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at android.app.ActivityThread.main(ActivityThread.java:4745)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at java.lang.reflect.Method.invokeNative(Native Method)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at java.lang.reflect.Method.invoke(Method.java:511)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-31 14:30:09.277: E/AndroidRuntime(22916):    at dalvik.system.NativeStart.main(Native Method)

这就是我如何使用排球

    GetStringRequest req = new GetStringRequest(Request.Method.GET,URL_API,
    new Response.Listener<String>() {
    // handle success response
    }, new Response.ErrorListener() {
    //handle error response
    @Override
public void onErrorResponse(VolleyError volleyError) {

    try {
        String error = new String(volleyError.networkResponse.data, HTTP.UTF_8);
        }
        catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
        e.printStackTrace();
        }
    });

有时我会在此行(269)

收到错误nullPointerException
String error = new String(volleyError.networkResponse.data, HTTP.UTF_8);

我不知道出了什么问题,任何人都知道吗?

3 个答案:

答案 0 :(得分:3)

有可能volleyError.networkResponse.data为空。我不确定你要用这行代码获得什么,但是与Volley一起工作并想要查看volleyError中的内容。你可以试试这个:

String error =  volleyError.toString();

然后您可以检查此字符串是否存在任何特定错误[至少我是这样做的]。 VolleyErrors可能是API定义的少数内容之一,例如超时错误,连接错误,服务器错误等。当然,如果要根据特定错误触发其他操作,则可能需要进一步解析字符串。

答案 1 :(得分:2)

似乎onErrorResponse在少数设备上的响应方式不同

onErrorResponse在少数设备上返回null(这是崩溃的原因)

  new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {
                    if(error.getMessage==NULL){
  Toast.makeText(cardview.this, "Failed to retrieve data", Toast.LENGTH_LONG).show();
                    }
                else{
                        Toast.makeText(cardview.this, error.getMessage().toString(), Toast.LENGTH_LONG).show();
                    }

                });

我也有同样的错误..因设备而异...你可能会发现它不会在某些设备上给出nullpointer异常。

答案 2 :(得分:0)

  

应用此代码希望这有助于

@覆盖 public void onErrorResponse(VolleyError volleyError){

  Log.v("VolleyError",volleyError.getMessage);

});

这将在您的日志中打印错误