解码php中的JSON对象

时间:2016-04-03 10:41:32

标签: java php android mysql json

我从我的Android应用程序发送一个JSON对象到我的Web服务。 (使用截击)。这是我的代码的一部分。

private void sendtoDB(final String ngno){

    String tag_string_req = "req_save_to_db";

    final JSONObject JSONdates = new JSONObject();

    for(int i = 0 ; i < dates.size() ; i++){

        try{
            JSONdates.put("date", dates.get(i));

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

    }

    StringRequest strReq = new StringRequest(Request.Method.POST,
            AppConfig.URL_UpdateDates, new Response.Listener<String>() {

        @Override
        public void onResponse(String response) { ....}


        @Override
        protected Map<String, String> getParams() {
            // Posting params to register url
            Map<String, String> params = new HashMap<String, String>();
            params.put("ngno", ngno);
            params.put("JSON", JSONdates.toString());
            return params;
        }
    };
    AppController.getInstance().addToRequestQueue(strReq, tag_string_req);
}

dates数组包含我想要存储在我的数据库中的几个日期字符串。下面是我的JSON对象的输出(JSONdates)。

{“dates”:[“Wed Mar 30 00:00:00 GMT + 05:30 2016”,“Thu Mar 31 00:00:00 GMT + 05:30 2016”}

我的问题是如何在我的php中接收这个JSON对象以及如何正确解码它并将每个日期值都变为一个变量,这样我就可以相应地执行sql查询。

这是我的PHP代码。

<?php
require_once 'include/DB_Functions.php';
$db = new DB_Functions();

if(isset($_POST['ngno']) && isset($_POST['JSON']) ){

     $ngno = $_POST['ngno'];
     $json = json_decode($_POST['JSON'], true);


     foreach($json){
         $date = $json['date'];
         $job = $db->updateDates($ngno, $date);

         if($job){
              $response["error"] = FALSE;
              echo json_encode($response);
         }

         else{
             $response["error"] = TRUE;
             $response["error_msg"] = "Unknown error occurred in Updating!";
             echo json_encode($response);
        }
    }

}

else{
    $response["error"] = TRUE;
    $response["error_msg"] = "Dates are missing!";
    echo json_encode($response);     
}
?>

updateDates函数

public function updateDates($ngno, $date){

    $stmt = $this->conn->prepare("INSERT INTO datepicker(ngno, date) VALUES($ngno, $date)");
    $result = $stmt->execute();
    $stmt->close();
}

我在forearch($ json)unpcepted')'附近出现语法错误。

非常感谢任何帮助。

编辑1:

改变了php代码中的foreach循环,如下所示

foreach($dates as $date){
    error_log[$date];
    $job = $db->updateDates($ngno, $date);

    if($job){
        $response["error"] = FALSE;
        echo json_encode($response);
    }

    else{
        $response["error"] = TRUE;
        $response["error_msg"] = "Unknown error occurred in Updating!";
        echo json_encode($response);
    }
}

但现在它说,PHP警告:为foreach()提供的参数无效 任何帮助伙计?我是编程新手,不知道如何修复它。

1 个答案:

答案 0 :(得分:0)

foreach($json){更改为foreach($json['dates'] as $date){并删除第$date = $json['date'];行。有关foreach语法

的详细信息,请参阅php manual about foreach