java jquery jsonp 跨域_Jquery跨域调用(JSONP)遇到error问题的解决

博客作者分享了自己在解决jQuery跨域调用时遇到的问题及解决方案。通过调整javascript和java代码,确保返回的字符串包含正确的jsonp回调函数名称,并以json格式返回,最终成功实现跨域请求。在成功回调中进行数据处理,而在错误回调中打印xhr对象。
摘要由CSDN通过智能技术生成

之前Jquery的跨域调用一直没有解决,不知道为什么老是执行error里的语句,今天花了点时间研究了一下,终于把问题解决了。

关键的地方是返回的字符串,返回的字符串必须包含jsonp的回调函数名称,而且要为json数据。

javascript代码

$.ajax({

url: http, //请求的url

dataType : "jsonp",

//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)

jsonp: "callback",

//自定义的jsonp回调函数名称"jsonpCallback",返回的json也必须有这个函数名称

jsonpCallback:"jsonpCallback",

success : function(json){

if(json.flag=="successfully")

{ console.log("request successfully");}

},

error: function(xhr,status,error)

{ console.log(xhr); }

});

java代码

return "jsonpCallback"+"({\"flag\":\"successfuly\"})";//返回必须是json字符串

浏览器返回的结果如下

jsonpCallback({"flag":"successfuly"})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值