ajax跨域解决办法

Posted xqnq2007

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ajax跨域解决办法相关的知识,希望对你有一定的参考价值。

在使用jquery的ajax作请求时,http://127.0.0.1:8080,类似这样的一个本地请求,会产生跨域问题,

解决办法一:

jsonp:

var url= "http://127.0.0.1:8080/botinterface/?p1="+input+"&callback=?";
jQuery(‘#input‘).val(‘‘);
replaceText(‘me‘,input);
$.ajax({
type: "POST",
url: url,
dataType:"jsonp",
success:function(data,textStatus,jqXHR){
console.log(data.result)
replaceText(‘robot‘,data.result)
},
error:function(xhr,textStatus){
alert(‘error‘);
console.log(‘错误‘)
},

})

也就是在请求中加入callback参数,同时将dataType设置为jsonp类型,

在服务器端的返回数据也要封装成jsonp类型,

tmpresult={"result":tmpanswer}
callback = request.GET[‘callback‘]
return HttpResponse(‘%s(%s)‘ % (callback,json.dumps(tmpresult)))

如上为django中返回jsonp格式数据的代码,其中request.GET[‘callback‘]获取到了请求中的jsonp函数。

















以上是关于ajax跨域解决办法的主要内容,如果未能解决你的问题,请参考以下文章

Jquery AJAX ASP.NET IIS 跨域 超简单解决办法

ajax 跨域无法携带cookie 解决办法

解决ajax跨域的办法,代理,cors,jsonp

Ajax跨域请求COOKIE无法带上的解决办法

Ajax 跨域请求 Cookie 无法携带/保存的解决办法

java Ajax跨域请求COOKIE无法带上的解决办法