gpt4 book ai didi

php - 如何使用ajax post将JSON数据传递给php

转载 作者:行者123 更新时间:2023-12-01 04:41:52 24 4
gpt4 key购买 nike

这是代码:(#debug div 文本如下所示)

$("#debug").text(JSON.stringify(data));
// Try to save to a file
$.ajax({
type: 'POST',
url: './json.php',
dataType: 'json',
data: JSON.stringify(data),
success: function(xhr, status, errorMessage) {
if( xhr.responseText == "Success" ) {
alert("Success!");
} else {
alert("response was "+xhr.responseText);
}
},
error: function(xhr, status, errorMessage) {
$("#debug").append("RESPONSE: "+xhr.responseText+", error: "+errorMessage);
}
});

JSON.php 页面是:

<?php
openlog("scriptLog.txt", LOG_PID | LOG_PERROR, LOG_LOCAL0);
$json = $_POST['json'];
// open syslog, include the process ID and also send
// the log to standard error, and use a user defined
// logging mechanism
syslog(LOG_DEBUG, "Received Data");

if (json_decode($json) != null) { /* sanity check */
$file = fopen('./data.json','w+');
fwrite($file, json_decode($json));
fclose($file);
} else {
syslog(LOG_DEBUG,"Failure");
return "Failure, json decode is null";
}
closelog();
return "Success";
?>

在日志中我得到:

3 月 14 日 14:50:54 scriptLog.txt[21902]:收到数据

3 月 14 日 14:50:54 scriptLog.txt[21902]:失败

在调试 div 文本中我得到:

{"1457981454959":{"id":1457981454959,"code":"1","title":"Test","date":"22/03/2016","description":"a Task"}}RESPONSE: , error: SyntaxError: JSON Parse error: Unexpected EOF

1) 如何查看发布的数据? IE。 “收到的数据:”+系统日志中的内容以查看其结构。2)JSON解析错误?我看到的大多数例子都使用这个 stringify 函数。然后他们使用 json_decode 来获取值。为什么会出现解析错误?

最佳答案

1) How can I examine the posted data? I.e. "Received Data: "+WHAT in syslog to see its structure.

据我了解,您正在调试代码,因此系统日志可能不是最好的主意。我只需使用浏览器网络控制台来查看请求的内容,并使用像这样的简单 php 文件来查看 $_POST 的内容:

<?php
echo json_encode($_POST);

在更复杂的情况下 - 使用实际的 debugger .

2) JSON parse error? Most examples I see use this stringify function. then they use json_decode to get the values. Why the parse error?

您正在尝试在 $_POST 中使用 json 键,但您没有指示 jQuery 添加它,因此您收到的不是您所期望的。

您的 $.ajax 调用存在一些问题,这里是注释版本:

$.ajax({
type: 'POST',
url: './json.php',
dataType: 'json', // Note: dataType is only important for the response
// jQuery now expects that your server code
// will return json

// here you need to add the 'json' key
data: {'json': JSON.stringify(data)},

// the success method has different order of parameters
//success: function(xhr, status, errorMessage) {
success: function(data, status, xhr) {
alert("response was "+data);
},
error: function(xhr, status, errorMessage) {
$("#debug").append("RESPONSE: "+xhr.responseText+", error: "+errorMessage);
}
});

现在,在服务器上,您将拥有带有序列化字符串的 $_POST['json'],您可以json_decode 它。

或者,您可以发送 JSON 数据而不进行序列化:

var data = {'test': 'abc'};

$.ajax({
type: 'POST',
url: './json.php',
// No 'JSON.stringify()', just send your data
data: data,
...
});

在服务器上,您将拥有带有 abc 值的 $_POST['test'] (因此您的 json 已转换为数组)。

关于php - 如何使用ajax post将JSON数据传递给php,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35995849/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com