如何解决跨域问题?

栏目: Json · 发布时间: 6年前

  • 由于浏览器同源策略(协议,域名,端口有任何一个的不同)的限制,访问非同源的数据需要进行跨域处理,如果非同源--有三种行为受到限制:

    • Cookie,LocalStorage无法读取
    • DOM和JS对象无法获得
    • AJAX请求无效(可以发送,但浏览器会拒绝响应)
如何解决跨域问题?

二. 实现跨域的方式有哪些?

  • JSONP
  • CORS(服务器端完成)
  • 使用反向代理服务器来实现跨域请求(服务器端完成)

三. JSONP

  • 实现原理:

    • 动态创建一个script标签
    • 将目标数据的地址放到script标签的src属性中,并在请求地址中拼接callback参数并携带回调函数名
    • 定义回调函数,当数据请求成功之后,回调函数被调用
  • JQ封装的ajax方法跨域请求:

    <script>
    $.ajax({
        type: 'GET',
        url: 'http://localhost:4000/jsonp3?callback=?', // ? 可以理解为下面的success方法。
        success: function (data) {
            // data就是服务器返回的数据
            console.log(data);
        },
        dataType: 'jsonp' // 必须要指定dataType为jsonp
    });
    </script>
    
    复制代码

四. CORS

  • Cross Origin Resource Share 跨域资源共享(后端完成)

    • 在服务端响应客户端的时候,请求头中带上 Access-Control-Allow-Origin", "*"
    // 设置允许跨域访问该服务, cors
    app.all('*', function (req, res, next) {
        res.header("Access-Control-Allow-Origin", "*");
        res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS');
        res.header('Access-Control-Allow-Headers', 'Content-Type','mytoken');
        next();
    });
    复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深入理解LINUX网络技术内幕

深入理解LINUX网络技术内幕

Christian Benvenuti / 夏安、闫江毓、黄景昌 / 中国电力出版社 / 2009-6 / 128.00元

Linux如此的流行正是得益于它的特性丰富及有效的网络协议栈。如果你曾经惊叹于Linux能够实现如此复杂的工作,或者你只是想通过现实中的例子学习现代网络,《深入理解Linux网络内幕》将会给你指导。同其他O'Reilly的流行书籍一样,《深入理解Linux网络内幕》清楚地阐述了网络的基本概念,并指导你如何用C语言实现。虽然早先的 TCP/IP经验是有用的,但初学者通过《深入理解Linux网络内幕》......一起来看看 《深入理解LINUX网络技术内幕》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

在线进制转换器
在线进制转换器

各进制数互转换器

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具