Android - JSONException没有值

时间:2013-03-18 12:52:28

标签: java android json login jsonexception

我知道这里有几个问题都有相同的主题和错误,但没有一个表明我的问题同样如此,所以我决定在这里发帖,希望有人帮我指出原因。 所以我正在尝试在我的应用程序中实现登录功能,这里是代码:

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,因此登录失败。 请帮我找出错误以及如何解决。谢谢。

1 个答案:

答案 0 :(得分:56)

您使用错误的对象在此avatar获取json.getString(KEY_AVA)值。它应该是json_user.getString(KEY_AVA)

此外,如果值不存在,您可以使用optString代替getString,而null只返回{{1}},而不是抛出异常。