繁体   English   中英

使用jsonp的Ajax get给出“ SyntaxError:missing; 声明前”错误

[英]Ajax get with jsonp gives “SyntaxError: missing ; before statement” error

我正在使用jQuery进行GET请求并以json格式获取响应。 但是,当我尝试使用它时,它会在浏览器开发人员工具控制台中抛出以下错误消息。

语法错误:丢失; 声明前[了解更多]主持人:1:10 >>

下面是我的代码。

$.ajax({
    type: "GET",   
        url: url,   
        async: false,
        cache: false,
        data: { "filter": "host.vars.osgroup==\"unix\""},
        jsonp: "callback",
        dataType: "jsonp",
        contentType: "application/json; charset=utf-8",
        headers: {
            accept:'application/json',
            "Authorization": "Basic " + btoa(username + ":" + password)
        }
        // },
        // success : function(data)
        // {
        //     console.log(data);
        // }

})
 .done(function(html) {
     $("#displayElement").append(html);
 });

仅当服务器的响应不是有效的JSONP格式时,才会发生此错误。 要清除您的东西,JSONP不是json。 这是您可以说的javascript脚本。 如果您使用的是说Php,那么您的php应该输出如下:

     header("Content-Type: application/json");    
     exit("mycallback(".json_encode(['error' => 0,'auth_token' => $_COOKIE['server_token']]).")");

您会看到Php代码正在输出一个字符串,该字符串具有以json格式的数据作为参数的javascript函数调用。 现在,在ajax调用中,您应该精简所有内容。 Ajax调用应如下所示:

     $.ajax({
        url:'http://ssoidpclient.local/get_auth_token',
        dataType: 'jsonp',
        jsonp: false,
        jsonpCallback: 'mycallback',
        success:function(data)
        {
        }

     });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM