跨域问题

2018-07-02  本文已影响0人  vckah

本质原因是同源策略,浏览器会检查 域名协议端口。
注意请求可以发过去,接收也可以,但是被浏览器阻止了。
浏览器为什么会阻止呢?原因是跨域,XHR(XMLHttpRequest) 请求
有两种方式可以解决

function test(arg) {
  var data=JSON.parse(arg);
}
function get_jsonp_data(url) {
  var ele_script=$("<script>");
  ele_script.attr("src": url);
  ele_script.attr("id", "jsonp");
  $("body").append(ele_script);
  $("#jsonp").remove()
}
// 点击一个 button 来请求
$(".get_service").click(function() {
  $.ajax({
    url: 'url',
    dataType: 'jsonp',
    jsonp:'callbacks',
    // jsonpCallback:"test",    指定具体回调函数,jquery 会随机生成字符串
    success: function (data) {
      console.log()
    }
  })
});
// 服务器解析然后返回字符串
-------------->>>> server >>>>--------------
func = request.GET.get('callbacks')
r = {"name": 'asd', "age", 23}
return HttpResponse("%s(%s)"%(func, json.dumps(info)))
// 这里 func 相当于 test
// 然后返回给浏览器一串字符,浏览器解析 script 标签进行 函数调用,相当于 test(r)

(1) 请求方法是以下三种方法之一:HEAD GET POST
(2)HTTP的头信息不超出以下几种字段:
Accept Accept-Language
Content-Language Last-Event-ID
Content-Type:只限于三个值application/x-www-form-urlencodedmultipart/form-datatext/plain
两者区别
简单请求:一次请求
非简单请求:两次请求,在发送数据之前会先发一次请求用于做“预检”,只有“预检”通过后才再发送一次请求用于数据传输。

# Django 的返回
ret = HttpResponse()
ret["Access-Control-Allow-Origin"] = "域名"
return ret
上一篇 下一篇

猜你喜欢

热点阅读