我第一次尝试使用Fetch API,我正在尝试将变量POST到PHP脚本。我用同样的jQuery.ajax()
做了同样的事情。
var myRequest = new Request('invoeren.php', {method: 'POST', body: JSON.stringify({name: name})});
fetch(myRequest).then(function(response) {
console.log(response);
});
这会返回给我Undefined index 'name'
。
我做错了什么?
正在运行的jQuery代码:
$.ajax({
url: "invoeren.php",
method: "POST",
data: { name : name}
}).done(function( msg ) {
console.log(msg);
}).fail(function( jqXHR, textStatus ) {
alert( "Naam is niet ingevoerd door een probleem: " + jqXHR );
});
PHP脚本:
try {
$dbh = new PDO('mysql:host=localhost;dbname=ajaxoef', $user, $pass);
$stmt = $dbh->prepare('INSERT INTO names(name) VALUES (:name)');
$stmt->bindParam(':name', $name);
$name = json_decode($_POST['name']);
$stmt->execute();
echo "Naam is ingevoerd.";
} catch (PDOException $e) {
print "Error!: " . $e->getMessage() . "<br/>";
die();
}
答案 0 :(得分:2)
正在运行的jQuery代码
数据:{name:name}
...所以当你使用jQuery时,你会发送WWW URL表单编码数据(默认的jQuery编码)。
body: JSON.stringify({name: name})
...但是当你切换到fetch时,你也将对象转换为JSON。
JSON不是WWW URL表单编码!
你可能没有重写PHP以期待JSON,并且可能试图从$_POST
读取(这是空的,因为默认情况下PHP不支持JSON编码的请求)。
您可以构造一个FormData对象,该对象将以PHP默认解析的方式进行编码。
var body = new FormData;
body.append("name", name);
//...
body: body