0

我正在构建一个需要连接到网络服务器上的 PHP API 以从 mySQL 数据库获取用户凭据的应用程序。API 将返回一个 JSON 对象作为登录的结果。

我在网上遵循了一个教程,它在主线程上构建了所​​有内容,所以我正在尝试执行异步任务。但是我无法让它工作并且我不断收到 NullPointerException。该应用程序花了大约 5 分钟尝试连接到我的 WAMP 服务器,然后就关闭了。连接到服务器以模拟糟糕的网络条件需要那么长时间吗?

代码在这里:

    private class ProcessLogin extends AsyncTask<Void, String, JSONObject> {
    @Override
    protected JSONObject doInBackground(Void... urls) {

      inputEmail = (EditText) findViewById(R.id.loginEmail);
      inputPassword = (EditText) findViewById(R.id.loginPassword);
      btnLogin = (Button) findViewById(R.id.btnLogin);
      btnLinkToRegister = (Button) findViewById(R.id.btnLinkToRegisterScreen);
      loginErrorMsg = (TextView) findViewById(R.id.login_error);

      String email = inputEmail.getText().toString();
      String password = inputPassword.getText().toString();

      publishProgress("Attempting to authenticate");

      JSONObject json = userFunction.loginUser(email, password);

       return json;
     }

    @Override
    protected void onPostExecute(JSONObject json) {

        publishProgress("Response received");

        try {
            if (json.getString(KEY_SUCCESS) != null) {
                publishProgress("correct username/password");
            }
            else {
                publishProgress("Incorrect username/password");
            }
        } catch (JSONException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

    /* (non-Javadoc)
     * @see android.os.AsyncTask#onProgressUpdate(Progress[])
     */
    @Override
    protected void onProgressUpdate(String... values) {
     super.onProgressUpdate(values);
        // Things to be done while execution of long running operation is in progress. For example updating ProgessDialog
        loginErrorMsg = (TextView) findViewById(R.id.login_error);
        loginErrorMsg.setText(values[0]);
     }
  }

   // Login button Click Event
   public void beginLogin(View view) {
     new ProcessLogin().execute();
   }

我的日志猫错误在这里:

08-29 20:19:50.462: E/AndroidRuntime(1287): FATAL EXCEPTION: main
08-29 20:19:50.462: E/AndroidRuntime(1287): java.lang.NullPointerException
08-29 20:19:50.462: E/AndroidRuntime(1287):     at             com.example.onepass.LoginActivity$ProcessLogin.onPostExecute(LoginActivity.java:75)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at com.example.onepass.LoginActivity$ProcessLogin.onPostExecute(LoginActivity.java:1)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.os.AsyncTask.finish(AsyncTask.java:631)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.os.AsyncTask.access$600(AsyncTask.java:177)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.os.Looper.loop(Looper.java:137)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at android.app.ActivityThread.main(ActivityThread.java:4745)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at java.lang.reflect.Method.invokeNative(Native Method)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at java.lang.reflect.Method.invoke(Method.java:511)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
08-29 20:19:50.462: E/AndroidRuntime(1287):     at dalvik.system.NativeStart.main(Native Method)

我刚刚开始使用 Android SDK 进行编码,所以如果错误非常明显,我深表歉意并感谢您的指点。

谢谢

4

1 回答 1

0

正如堆栈跟踪所示,错误位于 LoginActivity.java 的第 75 行:

在 com.example.onepass.LoginActivity$ProcessLogin.onPostExecute( LoginActivity.java:75 )

由于您没有提供行号,我的盲目猜测是您传递给 onPostExecute() 的 json 变量只是null. 正如您假设它始终有效(在 99% 的情况下这是错误的假设),您尝试在nulled 对象上调用 getString(),因此是 NPE。

解决方法是在使用它之前检查它json是否不为空,这始终是一个好习惯

于 2012-08-30T00:34:52.400 回答