【发布时间】:2013-01-06 08:49:55
【问题描述】:
我正在尝试使用Lukencode 的 RestClient 类在我的 Android 应用中实现登录功能。我有一个名为 UserFunctions 的类来通过 RestClient 检索 JSONObject:
public class UserFunctions {
private RestClient restClient;
private String json;
private Context mContext;
private static String login_tag = "login";
private static String register_tag = "register";
// constructor
public UserFunctions(Context context){
restClient = new RestClient("http://10.0.2.2:81/HGourmet/user");
mContext = context;
}
/**
* function make Login Request
* @param email
* @param password
* */
public JSONObject loginUser(String email, String password){
// Building Parameters
restClient.AddParam("tag", login_tag);
restClient.AddParam("email", email);
restClient.AddParam("password", password);
// getting JSON Object
try{
restClient.Execute(RequestMethod.POST);
}catch(Exception e){
e.printStackTrace();
}
json = restClient.getResponse();
JSONObject jObj = null;
try {
jObj = new JSONObject(json);
} catch (JSONException e) {
Log.e("JSON Parser", "Error parsing data " + e.toString());
}
return jObj;
}
以下是我在 logcat 中得到的:
01-06 09:01:05.805: E/Trace(1819): error opening trace file: No such file or directory (2)
01-06 09:02:05.485: E/AndroidRuntime(1819): FATAL EXCEPTION: main
01-06 09:02:05.485: E/AndroidRuntime(1819): java.lang.NullPointerException
01-06 09:02:05.485: E/AndroidRuntime(1819): at org.json.JSONTokener.nextCleanInternal(JSONTokener.java:116)
01-06 09:02:05.485: E/AndroidRuntime(1819): at org.json.JSONTokener.nextValue(JSONTokener.java:94)
01-06 09:02:05.485: E/AndroidRuntime(1819): at org.json.JSONObject.<init>(JSONObject.java:154)
01-06 09:02:05.485: E/AndroidRuntime(1819): at org.json.JSONObject.<init>(JSONObject.java:171)
01-06 09:02:05.485: E/AndroidRuntime(1819): at com.hanu.hgourmet.library.UserFunctions.loginUser(UserFunctions.java:49)
01-06 09:02:05.485: E/AndroidRuntime(1819): at com.hanu.hgourmet.LoginActivity$1.onClick(LoginActivity.java:56)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.view.View.performClick(View.java:4202)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.view.View$PerformClick.run(View.java:17340)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.os.Handler.handleCallback(Handler.java:725)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.os.Handler.dispatchMessage(Handler.java:92)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.os.Looper.loop(Looper.java:137)
01-06 09:02:05.485: E/AndroidRuntime(1819): at android.app.ActivityThread.main(ActivityThread.java:5039)
01-06 09:02:05.485: E/AndroidRuntime(1819): at java.lang.reflect.Method.invokeNative(Native Method)
01-06 09:02:05.485: E/AndroidRuntime(1819): at java.lang.reflect.Method.invoke(Method.java:511)
01-06 09:02:05.485: E/AndroidRuntime(1819): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-06 09:02:05.485: E/AndroidRuntime(1819): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-06 09:02:05.485: E/AndroidRuntime(1819): at dalvik.system.NativeStart.main(Native Method)
我真的希望有人能帮我找出这个问题的原因。非常感谢。
【问题讨论】:
-
public JSONObject loginUser(String email, String password)返回jObj,但不创建jObj。也许这是你的问题? -
jObj在我调用new GetUser().execute();时已经创建,不是吗? -
这太令人沮丧了。难道你没有意识到 logcat 堆栈跟踪会准确地告诉你错误在哪一行? Toast 不是调试的好方法。使用调试器单步执行您的代码。同时,请发布异常的堆栈跟踪。
-
No
jObj不会被初始化,因为GetUser是一个AsyncTask,它在不同的线程中运行,并且在调用new GetUser().execute();之后,控件不会等待AsyncTask完成并且控件向前移动并且返回未初始化的jObj。 -
@strawberryjam 发布堆栈跟踪... errr... 西蒙说发布堆栈跟踪。如果没有堆栈跟踪的可能性,您只会收到有关丢失堆栈跟踪的投诉,或者是对问题的猜测。
标签: java android json rest nullpointerexception