Fetch api不发送POST数据

时间:2017-06-14 15:44:01

标签: javascript fetch fetch-api

我第一次尝试使用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();
}

1 个答案:

答案 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