我正在尝试跨域访问数据(在本地测试),但数据始终无法加载。
$.ajax({
type: 'POST',
url: 'http://localhost/php/ajax/json.php',
dataType: 'jsonp',
data: {action: 'get_json'},
success: function(data) {
console.log(data);
},
error: function() {
console.log("Error loading data");
}
});
PHP 如下所示(函数通过文件前面的 switch 语句调用)。
function get_json() {
$mysqli = db_connect();
$sql = "SELECT * FROM json_test";
$result = $mysqli->query($sql);
$rows = array();
if ($result->num_rows > 0) {
while ($row = $result->fetch_assoc()) {
array_push($rows, $row);
}
}
echo $_GET['callback']."(".json_encode($rows).");";
}
标头设置在 PHP 文档的开头。
header('Content-Type: application/json');
我收到的错误(如果我自己运行 PHP 文件)是 Undefined index: callback
.在此错误之后,json 字符串作为文本正常回显。(我也试过echo $_POST[...]
)。
如何使此回调正常工作或如何正确定义它?任何帮助,不胜感激。
添加此参数:
&jsoncallback=?
我能够通过将回调更改为以下内容来修复PHP文件中的错误:
$callback = "";
if (array_key_exists('callback', $_GET) == TRUE) {
$callback = $_GET['callback'];
}
echo $callback."('".json_encode($rows)."');";
AJAX 查询现在还可以成功检索 JSON 数据。