`header(“Content-type:application / json”)的用法;`

时间:2016-02-09 06:04:05

标签: php jquery json ajax

我刚刚创建了一个JQuery ajax函数来从json-encoded检索一些PHP数据,这是我的代码:

文件名:bank.php

$('form').on('submit', function(){

        var datatobesent  = $(this).serialize();
        $.ajax({
            data: datatobesent,
            url:'data.php',
            type:'GET'
        })
        .done(function(data){
            console.log(typeof(data));
        });
        return false;
})

并在data.php我写了

if(isset($_GET)){
    $data = $_GET;
    echo json_encode($data);
    header("Content-type:application/json");
}
问题是,当我删除header("Content-type:application/json");中的data.php行时console.log告诉ajax返回的数据类型为string

当我在dataType :的{​​{1}}函数中添加ajax json``时,类型会更改为bank.php

那么实际上object的功能是什么?

1 个答案:

答案 0 :(得分:14)

函数header("Content-type:application/json")将http json标头发送到浏览器以通知他他期望的数据类型。您可以在浏览器中查看每个请求的所有http标头(如果您使用的是Chrome开放式开发人员工具,请转到网络,调整视图并重新加载页面,您将看到浏览器发出的所有请求,如果您点击任何在任何这些请求上,然后单击标题,您将看到每个请求的标题)。

使用此功能时,您会注意到服务器发送的响应中的http标头Content-Type:application/json。如果您不使用它,服务器将发送默认值,最有可能是Content-type:text/html; charset=UTF-8

正如@Monty所说,如果您向AJAX添加dataType: 'json',则不需要此功能,因为Jquery将处理数据,即使它是使用text / html标头发送的。

另请参阅:jQuery AJAX Call to PHP Script with JSON Return

要详细了解标题:http-headers-for-dummies