我知道这里有几个问题都有相同的主题和错误,但没有一个表明我的问题同样如此,所以我决定在这里发帖,希望有人帮我指出原因。 所以我正在尝试在我的应用程序中实现登录功能,这里是代码:
if (tag.equalsIgnoreCase(login_tag)){
// check for login response
try {
if (json.getString(KEY_SUCCESS) != null) {
String res = json.getString(KEY_SUCCESS);
if(Integer.parseInt(res) == 1){
// user successfully logged in
// Store user details in SQLite Database
DatabaseHandler db = new DatabaseHandler(mContext);
JSONObject json_user = json.getJSONObject("user");
// Clear all previous data in database
logoutUser(mContext);
Toast.makeText(mContext, json.toString(3), Toast.LENGTH_LONG).show();
db.addUser(json_user.getString(KEY_EMAIL), json_user.getString(KEY_NAME), json.getString(KEY_UID), json.getString(KEY_AVA), json_user.getString(KEY_BDAY), json_user.getString(KEY_COUNTRY), json_user.getString(KEY_PREF), json_user.getString(KEY_SPEND));
// Launch Dashboard Screen
Intent dashboard = new Intent(mContext, DashboardActivity.class);
// Close all views before launching Dashboard
dashboard.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
mContext.startActivity(dashboard);
// Close Login Screen
((Activity) mContext).finish();
}
}
} catch (JSONException e) {
e.printStackTrace();
}
}
这是我登录时收到的JSON响应:
{
"tag": "login",
"success": 1,
"error": 0,
"uid": "5123",
"user": {
"email": "abcxyz@gmail.com",
"name": "abc",
"avatar": "avatars/img_hzsxda_2013-03-18-11-03-33.jpg",
"bday": "1991-02-01",
"country": "Australia",
"preferences": "none",
"spending": "none"
}
}
显然avatar
有一个值,但我的logcat仍然有这个警告:
03-18 12:06:36.972: W/System.err(24574): org.json.JSONException: No value for avatar
由于没有得到任何价值的头像,我无法完成addUser
,因此登录失败。
请帮我找出错误以及如何解决。谢谢。
答案 0 :(得分:56)
您使用错误的对象在此avatar
获取json.getString(KEY_AVA)
值。它应该是json_user.getString(KEY_AVA)
。
此外,如果值不存在,您可以使用optString
代替getString
,而null
只返回{{1}},而不是抛出异常。