我正在构建一个需要连接到网络服务器上的 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 进行编码,所以如果错误非常明显,我深表歉意并感谢您的指点。
谢谢