5

我在我的 android 应用程序中尝试 volley 库

这是我的日志

    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();
        }
    });

有时我在这一行得到错误 nullPointerException (269)

String error = new String(volleyError.networkResponse.data, HTTP.UTF_8);

我不知道怎么回事,有人知道吗?

4

3 回答 3

4

volleyError.networkResponse.data 可能是空的。我不确定你想用这行代码得到什么,但使用 Volley 并想看看 volleyError 中有什么。你可以试试这个:

String error =  volleyError.toString();

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

于 2013-11-01T02:56:28.430 回答
3

似乎 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();
                    }

                });

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

于 2016-10-21T06:27:39.787 回答
0

应用此代码希望这会有所帮助

@Override public void onErrorResponse(VolleyError volleyError) {

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

});

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

于 2017-03-31T04:44:46.147 回答