【问题标题】:Null Pointer during AsyncTask() yet values are defined [duplicate]AsyncTask()期间的空指针但值已定义[重复]
【发布时间】:2018-12-12 19:01:32
【问题描述】:

我正在尝试用我的身份验证代码交换访问令牌。 我正在使用AsyncTaskRunner,但是,我收到了一个错误:

java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.String.length()' on a null object reference at java.net.URLEncoder.encode(URLEncoder.java:205).

这是我的请求参数:

CLIENT_ID = "1fb7c350-bb6a-5741-86b9-43afc2f1642f";
REDIRECT_URI = "https://xxxx.xxxxx.xxxx/rest/callback.html";
CLIENT_SECRET = "xxxxxxx";
GRANT_TYPE = "authorization_code";
ACCESS_TOKEN_URL = "https://xxxx.xxxxxx.com/oauth/token";

我的 AsyncTask 类

private class AsyncTaskRunner extends AsyncTask<String, String, String> {
    @Override
    protected String doInBackground(String... params) {
        try {
            URL url = null;
            InputStream stream = null;
            HttpURLConnection urlConnection = null;
            try {
                url = new URL(ACCESS_TOKEN_URL);
                urlConnection = (HttpURLConnection) url.openConnection();
                urlConnection.setRequestMethod("POST");
                urlConnection.setDoOutput(true);

                data = URLEncoder.encode("client_id", "UTF-8")
                        + "=" + URLEncoder.encode(CLIENT_ID, "UTF-8"); //*This line above is where the caused by exception is pointing to.*

                data += "&" + URLEncoder.encode("client_secret", "UTF-8") + "="
                        + URLEncoder.encode(CLIENT_SECRET, "UTF-8");
                data += "&" + URLEncoder.encode("grant_type", "UTF-8") + "="
                        + URLEncoder.encode(GRANT_TYPE, "UTF-8");
                data += "&" + URLEncoder.encode("code", "UTF-8") + "="
                        + URLEncoder.encode(authCode, "UTF-8");
                data += "&" + URLEncoder.encode("redirect_uri", "UTF-8") + "="
                        + URLEncoder.encode(REDIRECT_URI, "UTF-8");

                urlConnection.connect();

                OutputStreamWriter wr = new OutputStreamWriter(urlConnection.getOutputStream());
                wr.write(data);
                wr.flush();

                stream = urlConnection.getInputStream();
                BufferedReader reader = new BufferedReader(new InputStreamReader(stream, "UTF-8"), 8);
                String result = reader.readLine();
                accessToken = result;
                return accessToken;

            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                if (urlConnection != null) {
                    urlConnection.disconnect();
                }
            }

            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
                Log.i("Result", "SLEEP ERROR");
            }
            return null;
        } finally {
            Log.i("Result", "SLEEP ERROR");
        }
    }
}

在我的发送按钮上:

authCode = sharedPreferences.getString("code", null);
params=new String[5];
CLIENT_ID = params[0];
CLIENT_SECRET = params[1];
GRANT_TYPE = params[2];
REDIRECT_URI = params[3];
authCode = params[4];
new AsyncTaskRunner().execute(params);

这是我的完整日志:

07-04 11:43:57.749 7157-8120/almac.com.cameratutorialtest E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #2
Process: almac.com.cameratutorialtest, PID: 7157
java.lang.RuntimeException: An error occurred while executing doInBackground()
    at android.os.AsyncTask$3.done(AsyncTask.java:325)
    at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
    at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
    at java.util.concurrent.FutureTask.run(FutureTask.java:242)
    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:243)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
    at java.lang.Thread.run(Thread.java:761)
    Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.String.length()' on a null object reference
    at java.net.URLEncoder.encode(URLEncoder.java:205)
    at almac.com.cameratutorialtest.MainActivity$AsyncTaskRunner.doInBackground(MainActivity.java:275)
    at almac.com.cameratutorialtest.MainActivity$AsyncTaskRunner.doInBackground(MainActivity.java:256)
    at android.os.AsyncTask$2.call(AsyncTask.java:305)
    at java.util.concurrent.FutureTask.run(FutureTask.java:237)
    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:243) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
    at java.lang.Thread.run(Thread.java:761) 

上面设置后它是如何变为 null 的?为什么它没有检索到访问令牌?

【问题讨论】:

  • 格式化这个可怕的问题。它非常不可读。同样,仅粘贴所有代码也不会使这个问题更清楚。请告诉我们更多。堆栈跟踪很好,但我们没有行号,这对我们来说很难
  • 可能是你的 authCode 为空
  • 叹息。这是您的错误Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.String.length()' on a null object reference。解决这个问题
  • 抱歉@Lino 我编辑了它,因为我无法输入行号,我没有粘贴我认为需要的所有代码。我的 authcode 不是 null 我已经调试并打印了很多次,它有一个值
  • 我可以看到@ZUNJAE。这就是我问这个问题的原因。

标签: java android android-asynctask nullpointerexception oauth-2.0


【解决方案1】:

替换

authCode = params[4];

params[4] = authCode

就在这里

authCode = sharedPreferences.getString("code", null);
params=new String[5];
CLIENT_ID = params[0];
CLIENT_SECRET = params[1];
GRANT_TYPE = params[2];
REDIRECT_URI = params[3];
authCode = params[4];
new AsyncTaskRunner().execute(params);`

您将每个变量设置为 null 这不是您想要的,这就是您收到空指针错误的原因。

【讨论】:

  • 在空对象的同一行上还是同样的错误
  • 你能证明错误仍然存​​在吗?截取包含新代码和堆栈跟踪的屏幕截图。
  • 好的,不再崩溃,谢谢!但由于某种原因我仍然没有获得访问令牌。
  • 是的,这是一个完全不同的问题。考虑到确实解决了您的问题,将我的答案标记为正确
  • 或者创建一个新帖子或编辑您当前的帖子,因为现在您有多个问题并且您正试图将其放入一个提交中。
猜你喜欢
  • 2019-11-17
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-05-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-10-01
相关资源
最近更新 更多