正确的JSONP响应

7

我正在本地努力获取JSONP,以便将正确的响应传递到我的回调函数jsonp_callback中。使用来自以下链接的代码:How do I set up JSONP?

header('content-type: application/json; charset=utf-8');
$data = array ('a'=>1,'b'=>2,'c'=>3,'d'=>4,'e'=>5); 
echo $_GET['jsonpCallback'] . '('.json_encode($data).')';

并且

$.ajax({
    url: 'jsonp-response.php', 
    dataType:'jsonp',
    jsonp: 'jsonp_callback',
    success: function (r){
        console.log(r);
    }
});


function jsonp_callback (r){
    console.log('jsonp_callback:',r);
}

目前我得到的响应看起来像:

jQuery1102035954900085926056_1381230228656({"a":1,"b":2,"c":3,"d":4,"e":5})

查看测试静态jsonp响应第一个答案,我认为我做得对,但我不确定为什么jQuery给了我一个唯一的字符串。

我该如何让我的响应看起来像这样?

jsonp_callback({"a":1,"b":2,"c":3,"d":4,"e":5})

你的响应是否可能是一个字符串而不是JSON对象?你能检查一下吗? - JoeFletch
成功函数返回一个对象。 - invad0r
抱歉,我误读了您最初的帖子。我现在明白了。我不熟悉设置 jsonp 属性,但您是否尝试在 success 属性中使用以下代码?success: function (r){ jsonp_callback(r); } - JoeFletch
将包括 jsonp_callback(r) 在内的内容转换为 success 将会奏效。 - invad0r
2个回答

1
这是我的代码片段。如果它可以解决你的问题...
客户端代码:
设置jsonpCallBack为“photos”,dataType为“jsonp”。
 $('document').ready(function() {
            var pm_url = 'http://localhost:8080/diztal/rest/login/test_cor?sessionKey=4324234';
            $.ajax({
                crossDomain: true,
                url: pm_url,
                type: 'GET',
                dataType: 'jsonp',
                jsonpCallback: 'photos'
            });
        });
        function photos (data) {
            alert(data);
            $("#twitter_followers").html(data.responseCode);
        };

服务器端代码(使用Rest Easy)
@Path("/test_cor")
@GET
@Produces(MediaType.TEXT_PLAIN)
public String testCOR(@QueryParam("sessionKey") String sessionKey, @Context HttpServletRequest httpRequest) {
    ResponseJSON<LoginResponse> resp = new ResponseJSON<LoginResponse>();
    resp.setResponseCode(sessionKey);
    resp.setResponseText("Wrong Passcode");
    resp.setResponseTypeClass("Login");
    Gson gson = new Gson();
    return "photos("+gson.toJson(resp)+")"; // CHECK_THIS_LINE
}

-1

像这样:

$.ajax({
    url: 'jsonp-response.php', 
    dataType:'jsonp',
    jsonp: 'jsonp_callback',
    success: jsonp_callback 
});

function jsonp_callback (r) {
    console.log('jsonp_callback:',r);
}

在你的代码中,你从未使用过你定义的jsonp_callback函数。你只是编写了一些匿名的成功回调函数。jQuery注意到你使用了一个匿名函数,这就是为什么它生成了这个随机名称,以便可以调用匿名回调函数。

是的,它会传递到函数jsonp_callback中。在标题中的响应仍然看起来像 jQuery11020983548907097429_1381238805774({"a":1,"b":2,"c":3,"d":4,"e":5}) - invad0r

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接