我从我的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()提供的参数无效 任何帮助伙计?我是编程新手,不知道如何修复它。
答案 0 :(得分:0)
将foreach($json){
更改为foreach($json['dates'] as $date){
并删除第$date = $json['date'];
行。有关foreach语法