douqie1816 2014-03-20 08:51
浏览 61
已采纳

JsonException:userid没有值

I am having an issue where my json object array isn't passing the values. I know they are there, but I can't get them to pass into the variables in my android app.

The Java function to handle the JSONObject:/**
     * Function to get all userlogs
     **/
    public JSONObject getUserLogs(String userid){
     // userlogs JSONArray
       List<NameValuePair> params = new ArrayList<NameValuePair>();
       params.add(new BasicNameValuePair("tag", getUserLogs_tag ));
       params.add(new BasicNameValuePair("userid", userid));
       JSONObject json = jsonParser.getJSONFromUrl(getAllUserLogs,params);

       return json;
   }

Here is the Java do in backgrond:

protected String doInBackground(String... args) {
            //List<NameValuePair> params = new ArrayList<NameValuePair>();
            DatabaseHandler db = new DatabaseHandler(getApplicationContext());  

            HashMap<String,String> user = new HashMap<String, String>();
            user = db.getUserDetails();
            userid = user.get("uid");        

            UserFunctions userFunction = new UserFunctions();
            JSONObject json = userFunction.getUserLogs(userid);
            Log.d("All userlogs: ", json.toString());
           // return json;
            try {
                if (json.getString(KEY_SUCCESS) != null) {
                    userlogs = json.getJSONArray(KEY_USERLOGS);
                    // looping through All Products
                    for (int i = 0; i < userlogs.length(); i++) {
                        JSONObject c = userlogs.getJSONObject(i);

                        // Storing each json item in variable
                        String userID = c.getString(KEY_USERID);
                        String medname = c.getString(KEY_MEDNAME);
                        String medtaken = c.getString(KEY_MEDTAKEN);
                        String tabsleft = c.getString(KEY_TABSLEFT);

                        // creating new HashMap
                        HashMap<String, String> map = new HashMap<String, String>();

                        // adding each child node to HashMap key => value
                        map.put(KEY_USERID, userid);
                        map.put(KEY_MEDNAME, medname);
                        map.put(KEY_MEDTAKEN, medtaken);
                        map.put(KEY_TABSLEFT, tabsleft);

                        // adding HashList to ArrayList
                        logList.add(map);
                    }
                 }

                }
                catch (JSONException e) {
                    e.printStackTrace();

                }
            return null; 
        }

Here is the results:

03-20 04:47:01.212: E/JSON(7034): {"tag":"getUserLogs","success":1,"error":0,"userlogs":[{"userlogs":{"userid":"3705","medname":"atorvastatin 20mg","medtaken":"2014-03-20 03:48:49","tabsleft":"30"}},{"userlogs":{"userid":"3705","medname":"atorvastatin 20mg","medtaken":"2014-03-20 03:55:54","tabsleft":"30"}}]}
03-20 04:47:01.212: D/All userlogs:(7034): {"error":0,"success":1,"userlogs":[{"userlogs":{"userid":"3705","medtaken":"2014-03-20 03:48:49","tabsleft":"30","medname":"atorvastatin 20mg"}},{"userlogs":{"userid":"3705","medtaken":"2014-03-20 03:55:54","tabsleft":"30","medname":"atorvastatin 20mg"}}],"tag":"getUserLogs"}
03-20 04:47:01.212: W/System.err(7034): org.json.JSONException: No value for userid
03-20 04:47:01.212: W/System.err(7034):     at org.json.JSONObject.get(JSONObject.java:355)
03-20 04:47:01.212: W/System.err(7034):     at org.json.JSONObject.getString(JSONObject.java:515)
03-20 04:47:01.212: W/System.err(7034):     at com.jipe.medicationstation.UserlogListActivity$LoadAllLogs.doInBackground(UserlogListActivity.java:104)
03-20 04:47:01.212: W/System.err(7034):     at com.jipe.medicationstation.UserlogListActivity$LoadAllLogs.doInBackground(UserlogListActivity.java:1)
03-20 04:47:01.212: W/System.err(7034):     at android.os.AsyncTask$2.call(AsyncTask.java:288)
03-20 04:47:01.212: W/System.err(7034):     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
03-20 04:47:01.212: W/System.err(7034):     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
03-20 04:47:01.212: W/System.err(7034):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
03-20 04:47:01.212: W/System.err(7034):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
03-20 04:47:01.212: W/System.err(7034):     at java.lang.Thread.run(Thread.java:841)

The PHP:

else if ($tag == 'getUserLogs') {
       $userid = $_POST['userid'];
       //Special case (normally conntections handled in functions/config or connect)
       $link = new mysqli($host, getDBuser(), getDBpassword(), getDBname());
        /* check connection */
        if (mysqli_connect_errno()) {
            $response["error"] = 1;
            $response["error_msg"] = mysqli_connect_error();
            echo json_encode($response);
        }
        $query = "SELECT * FROM userlog WHERE userid = '$userid'";
        $result = mysqli_query($link, $query);
        $row_cnt = mysqli_num_rows($result);
        //If results, then
        if( $row_cnt > 0){
            $response["userlogs"] = array();
            while($row = mysqli_fetch_array($result, MYSQLI_BOTH)){
                $userlog = array();
                $userlog["userlogs"]["userid"] = $row["userid"];
                $userlog["userlogs"]["medname"] = $row["medname"];
                $userlog["userlogs"]["medtaken"] = $row["medtaken"];
                $userlog["userlogs"]["tabsleft"] = $row["tabsleft"];
                array_push($response["userlogs"], $userlog);
            }
            $response["success"] = 1;
            echo json_encode($response);
            mysqli_close($link);
        }
        else {
            // userlogs not found
            // echo json with error = 1
            $response["error"] = 1;
            $response["error_msg"] = "No Userlogs found";
            echo json_encode($response);
        }
    }
    else {
        $response["error"] = 3;
        $response["error_msg"] = "JSON ERROR";
        echo json_encode($response);
    }
} 

Any suggestions?

  • 写回答

1条回答 默认 最新

  • donglang5157 2014-03-20 08:55
    关注

    You have

    "userlogs": [ // jsonarray userlogs
        {         // json object node
            "userlogs": {   // json object userlogs
    

    Then

    userlogs = json.getJSONArray(KEY_USERLOGS); // fine 
    for (int i = 0; i < userlogs.length(); i++) {
    JSONObject c = userlogs.getJSONObject(i);
    

    But you have a JSONObject userlogs also

    JSONObject userlogsobject = c.getJSONObject("userlogs");
    String userID = userlogsobject.getString(KEY_USERID);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 蓝牙耳机怎么查看日志
  • ¥15 Fluent齿轮搅油
  • ¥15 八爪鱼爬数据为什么自己停了
  • ¥15 交替优化波束形成和ris反射角使保密速率最大化
  • ¥15 树莓派与pix飞控通信
  • ¥15 自动转发微信群信息到另外一个微信群
  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏