阿贾克斯赢得了't将数据发送到PHP

Ajax won't send data to PHP

本文关键字:数据 PHP 阿贾克斯      更新时间:2023-09-26

SOLVED:这里发布的代码是正确的,但连接到数据库的一些PHP代码需要修复,我现在可以工作了。我在评论中使用了Quentin的建议来解决我的问题。

我试图通过ajax将数组的JSON发送到PHP文件,然后运行PHP文件。这是我的ajax:

    $('#submit').click(function() {
  $.ajax({
    method: "POST",
    url: "submit.php",
    data: {selectedImageArray: selectedImageArray}
  }).done(function( msg ) {
    alert( "Data Saved: " + selectedImageArray );
  });
});

在我的PHP文件中,我连接到一个数据库,然后有这样的:

$array = $_POST['selectedImageArray'];
    $sql = $dbh->prepare("INSERT INTO pending_trades (steam_id, trade_items, is_giving, is_receiving, has_started) VALUES (:steamid, :itemlist, '1', '0', '0')");
    $sql->bindParam(':steamid', $steamprofile['steamid']);
    $sql->bindParam(':itemlist', $array);
    $sql->execute();

我希望它将"selectedImageArray"json发送到php,并在按下以下按钮时使用它运行msql查询:

<button id="submit" class="button1" >Submit<span></span></button>

当单击按钮时,我会得到"datasaved:array data"消息,但php代码没有运行。为什么不起作用?

EDIT:我设置了data: {selectedImageArray: selectedImageArray}而不是data: selectedImageArray,因为我被告知它会将其转换为JSON格式,对吗?

您正在数据库中添加一个数组而不是字符串,请尝试使用:

$sql->bindParam(':itemlist', json_encode($array));

当你得到数据时,只需运行:

$array = json_decode($itemlist);

首先查看浏览器调试器,了解真正发送到php文件的内容。第二件事:你将向它发送JSON。这意味着,你有一个POST表单数组,如下所示:

[{
   "key1": "value1",
   "key2": "value2"
}]

因此,总之,这是行不通的:

$array = $_POST['selectedImageArray'];

您需要直接访问例如$_POST['key1']

您可以添加内容类型JSON。另一方面,它将被视为文本。

var data = JSON.stringify({selectedImageArray: selectedImageArray});
 $.ajax({
method: "POST",
dataType: 'json', // If your response is JSON
contentType: "application/json",
url: "submit.php",
data: data
}).done(function( msg ) {
alert( "Data Saved: " + selectedImageArray );
include ('submit.php');
});