【问题标题】:Volley onErrorResponse Give NullPointerExceptionVolley onErrorResponse 给出 NullPointerException
【发布时间】:2013-10-31 07:47:23
【问题描述】:

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

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

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

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

【问题讨论】:

  • 那一行是 String error = new String(volleyError.networkResponse.data, HTTP.UTF_8);
  • 您可以尝试检查volleyErrorvolleyError.networkResponsevolleyError.networkResponse.data是否为空。
  • 我一直在做,但仍然出现错误
  • 哪个变量为空?
  • 你最好学习Java。你应该通过if(volleyError != null)检查null

标签: android nullpointerexception android-volley


【解决方案1】:

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

String error =  volleyError.toString();

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

【讨论】:

  • 我的应用程序尝试获取 volleyError.networkResponse.statusCode 以便在出现错误时通知用户错误是服务器崩溃 (500) 还是无效请求 (403) 或未找到 (404) .这就是原因(例如)
【解决方案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();
                    }

                });

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

【讨论】:

    【解决方案3】:

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

    @覆盖 public void onErrorResponse(VolleyError volleyError) {

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

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2018-06-12
      • 2016-11-28
      • 2019-10-29
      • 2017-04-24
      • 2015-08-12
      • 2021-08-13
      • 2017-06-21
      • 1970-01-01
      相关资源
      最近更新 更多