javascript - 将 JSONP 提交到 PHP

标签 javascript php jquery json ajax

作为我的应用程序的一部分,我想将 JSON 对象提交到 PHP 脚本,该脚本返回 JSON 响应。该域不遵循同源策略,即 JSON 是从不同的域提交的,因此经过一些研究,我明白我需要使用 JSONP。现在花了10多个小时,我想不出任何其他解决方案。谁能帮助我了解我的问题出在哪里?

Javascript 片段:

var jsondata = {
        "variablA": "valueA",
        "variables": {
            "variableB": "valueB",
            "variableC": "valueC"
        };

        var encodedjson = JSON.stringify(jsondata);



        $.ajax({
            url: 'update.php',
            type: 'POST',
            contentType: 'application/json',
            dataType: "jsonp",
            data: {
                "data": encodedjson
            },
            success: function(data) {
                alert(data);
            },
            error: function(xhr, ajaxOptions, thrownError) {
                //On error do this
                $.mobile.loading('hide')
                if (xhr.status == 200) {

                    alert(ajaxOptions);
                } else {
                    alert(xhr.status);
                    alert(thrownError);
                }
            }
        });

PHP:

$array = json_decode($_REQUEST['data'], true);

$valueA = $array['variableA'];
$valueB = $array['variables']['variableB'];
$valueC = $array['variables']['variableC'];


$values = array('variableB' => $valueB, 'variableC' => $valueC);

$respencode = array('variableA' => $valueA, 'variables' => $values);

header('Content-type: application/json');
echo json_encode($respencode);

最佳答案

为了让 Ajax 知道它正在处理 jsonP 请求,您需要使用回调查询字符串重写 url,如下所示:

url: 'update.php?callback=?'

关于javascript - 将 JSONP 提交到 PHP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38365365/

相关文章:

javascript - 使用 jscript 从 Div 获取文本

javascript - MSIE版本不同

php - '?doing_wp_cron='

jquery - <li> 的页面转换不起作用

javascript - 剑道网格批量编辑

javascript - 如何获取 jQuery 生成的单选按钮的值

javascript - javascript中的setTimeout不给浏览器 'breathing room'

php - Docker PHP 和 FreeTDS - 在已知安装目录中找不到 freetds

php - Symfony2 与 KnpGaufrette 与 S3 与 LiipImagine

javascript - jQuery 全局对象在函数内不起作用