解决跨域问题(详解9种方法)

同源策略:端口号、协议、域名相同 。

一、为什么会出现跨域问题
        出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。同源策略会阻止一个域的javascript脚本和另外一个域的内容进行交互。所谓同源(即指在同一个域)就是两个页面具有相同的协议(protocol),主机(host)和端口号(port)

二、什么是跨域
        当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域。为了保证用户信息的安全性,防止恶意窃取当前网站的数据,禁止不同域直接与js代码交互。

分布式项目:把后台放在一个服务器里,把前台放在一个服务器中,防止文件相互损坏,防止一个模块导致所有程序运行不起来,可以前后台同时开发,用来节省时间。

跨域限制:

无法获取dom,ajax不能发送,cookie、localstorage、indexDB等本地存储不能读取

解决跨域的方法:

不常用方法


1.document.domain.iframe 解决跨域
  当前页面请求路径,iframe另一个域名的路径
  var iframe = document.getElementById("iframe");
  iframe.contentWindow.document.DOM
  
2.window.name](http://2.window.name) + iframe 解决跨域
  在iframe下嵌入一个外网的地址,获取iframe下的元素
  [window.name](http://window.name) = "XXX"
  window.location = url
  另一个页面中访问:window.name.document
  
3.location.hash + iframe 解决跨域
  location.hash = ""

常用方法:

4.Web Workers 解决跨域
  window.postMessage()
    window.postMessage("发送的内容");
    window.onMessage = function(data){//data接收参数}

5.websocket 解决跨域
  必须要有后台,通过websocket对象,向后台传递。
  var s = new WebSocket("路径")//ws的路径 包括外网
  s.send(发送的数据)
  window.onMessage = function(data){//data接收参数}

6.jsonp + ajax连用 解决跨域 
  用来解决原生ajax和jquery
  function fun(){}
  ajax.callback = fun

7.后台解决方式:CORS跨域资源共享

*** 8.nginx服务器 解决跨域
  在Nginx里html文件夹下,放置项目
  在conf文件夹下,修改配置文件,设置服务器参数:端口号,地址,
  默认首页,错误页面,代理地址(解决跨域)
  
*** 9.vue 和 react 配置项目文件
  vue.config.js 配置文件:跨域,全局变量等
  在vue的配置文件中设置代理:
  module.exports = { //导出对象
    devServer: { //设置代理服务器
    open: true, //允许
    host: 'localhost', //vue的地址
    port: 8080, //端口号
    //这里的ip和端口是前端项目的;下面为需要跨域访问后端项目
    proxy: { //外网代理信息对象
      '/api': { //设置访问服务器的名称
      target: '[http://wthrcdn.etouch.cn/](http://wthrcdn.etouch.cn/)',
      //这里填入你要请求的接口的前缀
      ws:true,//代理websocked
      changeOrigin:true,//虚拟的站点需要更管origin
      secure: true, //是否https接口
      pathRewrite:{
        '^/api':''//重写路径
      },
      headers: {
        referer: '[http://wthrcdn.etouch.cn/](http://wthrcdn.etouch.cn/)',
         //这里后端做了拒绝策略限制,请求头必须携带referer,否则无法访问后台
      }
      }
    }
    }
  }

  • 3
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
随着Web应用程序的不断发展,越来越多的Web开发者需要处理跨域访问的问题。尤其在网站开发中,标签<iframe>存在一些跨域问题,需要得到解决解决这些问题的一方案是使用反向代理服务器。Nginx是一个功能强大的开源服务器软件,可以用来提供反向代理服务,也可以作为Web服务器、邮件服务器和负载均衡器。 在使用Nginx作为反向代理服务器时,可以按如下步骤解决iframe跨域问题: 1.安装和配置Nginx。首先,您需要在服务器上安装Nginx,并确保nginx.conf文件正确配置。配置反向代理服务器,将请求从原始服务器发送到新的服务器。 2.设置虚拟主机。为了使Nginx适用于您的网站,需要设置虚拟主机,配置主机的ip格式和端口号。通常情况下,虚拟主机可以支持多个域名和主机名,可以同时接收多个请求。 3.设置location指令。为了完成反向代理任务,可以使用location指令,将请求传递给正确的服务器,并且从指定的URL获取响应。具体而言,您需要在nginx.conf文件中指定location指令,并告诉Nginx需要向哪个服务器发送请求。 4.启用SSL。如果您的网站需要安全的传输,比如HTTPS,那么您可以使用SSL/TLS加密功能。在Nginx中配置SSL,需要使用SSL module或者OpenSSL来启用。 总之,Nginx是一个非常强大的反向代理服务器,可以很好地解决网站开发中的问题。利用其反向代理功能,您可以很容易地解决iframe跨域访问的问题,确保您的Web应用程序能够正常运行并保持安全性和高可用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值