美文网首页
跨域问题

跨域问题

作者: vckah | 来源:发表于2018-07-02 22:30 被阅读0次

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

    • jsonp
      前端利用 script 标签去请求。如果利用 ajax 的方式去请求呢,其实就是往页面中添加 script 标签。这样的话,请求类型是 script 类型,这样浏览器就不会禁止了。
    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)
    
    • CORS
      又分为简单请求和复杂请求
      只要满足以下条件,就属于简单请求

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

    • 关于“预检”
      请求方式:OPTIONS
      “预检”其实做检查,检查如果通过则允许传输数据,检查不通过则不再发送真正想要发送的消息
    • 如何“预检”
      => 如果复杂请求是PUT等请求,则服务端需要设置允许某请求,否则“预检”不通过
      Access-Control-Request-Method
      => 如果复杂请求设置了请求头,则服务端需要设置允许某请求头,否则“预检”不通过
      Access-Control-Request-Headers
    • 支持跨域,简单请求
      服务器设置响应头:Access-Control-Allow-Origin = '域名' 或 '*'
    # Django 的返回
    ret = HttpResponse()
    ret["Access-Control-Allow-Origin"] = "域名"
    return ret
    
    • 支持跨域,复杂请求
      由于复杂请求时,首先会发送“预检”请求,如果“预检”成功,则发送真实数据。
      “预检”请求时,允许请求方式则需服务器设置响应头:Access-Control-Request-Method
      “预检”请求时,允许请求头则需服务器设置响应头:Access-Control-Request-Headers

    相关文章

      网友评论

          本文标题:跨域问题

          本文链接:https://www.haomeiwen.com/subject/enjruftx.html