跨域的三种解决方式

放咩咩的星星 放咩咩的星星     2022-10-05     683

关键词:

跨域问题

跨域问题对于WEB前端工程师来说是比较重要的一个问题,因为我们时常需要去解决这样的问题,在其他类型的前端开发来说,他们并没有跨域问题

跨域问题的产生

因为浏览器有同源策略:只有在同域名,同端口,同协议的情况下才可以进行数据交互;

有的时候,例如,在公司开发项目的时候,前端开发的服务器可能和后端服务器不是同一个,因为可能是通过gulp、webpack搭建的开发服务器,就需要解决跨域问题,再例如,在大公司有,数据服务器不只有一个,所以跨域问题也必然存在

解决方法

jsonp

是一种前后端结合的跨域方式,原理就是通过script标签的src属性来进行数据请求,因为其不受同源策略的影响,故而能请求到数据,需要注意的是,数据处理需要通过回调函数来进行,而本质上,我们把回调函数的名字告诉后端,后端将数据放入到回调函数里,所以说需要告知后端,回调函数是什么,这也就是为什么说是前后端结合的方式。

注意:一个script只能请求一次,多次请求应该去动态的创建script,回调函数也只能使用一次,所以也需要动态创建 ,使用完成后移除,避免污染全局空间

缺点:只能get请求

 

nodejs:

  app.get(‘/data‘, function (req, res) {

      //后端的任务,就是把数据放到前端的那个函数里并给它执行一下

      //直接返回这个操作的js字符串,因为这个字符串会被script当成js代码来运行

      //前端回调函数的名字

      let fn = req.query[‘callback‘]

      var content = fs.readFileSync(‘./datas/data.json‘)+‘‘

      //返回给前端函数数据

      res.send(fn+‘(‘+content+‘)‘);

  });

 

  js:

  Jsonp({

      url:"http://localhost:3000/data",

      success(results){

          console.log(results)

      }

  })

  function Jsonp({url,success}) {

      //动态创建script标签

      let $script = $("<script>")

 

      //随机函数名字

      var random_name = ‘random_fn_‘+Date.now()

      //创建的随机全局函数

      window[random_name] = function(data){

          success(data)

          //处理完数据之后,将script删掉,函数delete掉

          $script.remove()

          delete window[random_name]

 

      }

      $script[0].src = url+‘?callback=‘+random_name

      $("body").append($script)  

  }

cors

纯后端的解决方式,每次请求都会有一个origin信息被后端捕捉,后端可以通过设置对这个origin的域允许访问来解决跨域问题

node:

   app.get("/data_cors",(req,res)=>{

       //此次请求的源信息

       var reqOrigin = req.header("origin");  

       //如果源信息存在,且源是运行访问的

       if(reqOrigin !=undefined && reqOrigin.indexOf("http://localhost:9000") > -1){ 

       //设置允许 http://localhost:3000 这个域响应 

       res.header("Access-Control-Allow-Origin", "http://localhost:9000");  //允许这个域访问

       res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");  //允许的请求方法

       res.header("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With"); 

       } 

       res.send(‘123‘)

   })

 

   js:

   $.ajax({

       url:"http://localhost:3000/data_cors",

       success(results){

           console.log(results)

       }

   })

服务端代理proxy

因为服务器间的数据交互没有跨域限制,所以我们可以通过一个中间代理服务器来请求目标服务器的数据,也就是开发服务器发送请求到代理服务器,代理服务器再请求目标服务器,将数据返回给开发服务器

目标服务器接口 3000:

  app.get("/data_proxy",(req,res)=>{

      //此次请求的源信息

      res.send(‘proxy‘)

  })

 

  代理服务器1234:

  app.get("/to3000",(req,res)=>{

      //代理服务器1234对9000做跨域处理

      var reqOrigin = req.header("origin");  

      //如果源信息存在,且源是运行访问的

      if(reqOrigin !=undefined && reqOrigin.indexOf("http://localhost:9000") > -1){ 

      //设置允许 http://localhost:3000 这个域响应 

      res.header("Access-Control-Allow-Origin", "http://localhost:9000");  //允许这个域访问

      res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");  //允许的请求方法

      res.header("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With"); 

      }

      //获取到9000真正要调用的3000目标服务器的接口

      var url = req.query[‘url‘]

      let _res = res

      //代理服务器1234像目标服务器3000发送请求(没有跨域限制)

      http.get(url,(res)=>{

          let result=‘‘

          res.on("data",(chunk)=>{

              result+=chunk

          })

          res.on("end",()=>{

              console.log(result)

              //代理服务器1234将请求到的目标服务器3000的数据返回给开发服务器9000

              _res.send(result)

          })

      })

  })

  app.listen(1234);

 

  开发服务器9000:

  //当前服务器9000向代理服务器1234发送请求

  $.ajax({

      url:"http://localhost:1234/to3000",

      data:{

          url:"http://localhost:3000/data_proxy"

      },

      success(results){

          console.log(results)

      }

  })

跨域的三种解决方案

参考技术A跨域问题的出现是由于浏览器为了防止csrf攻击,避免恶意攻击而采取的同源策略限制,也就是当一个页面使用XMLHTTPRequest对象发送HTTP请求时(XHR),必须保证当前页面和请求的资源是同源的(即协议,域名和端口号要完... 查看详情

前端跨域的三种解决方案

1.CORS跨域  前端不动 后端配合  像调用正常的接口一样调用接口,通过后端修改配置使得站点能够访问 2.JSONP跨域(github网址:https://github.com/webmodules/jsonp)  前端适配(安装jsonp插件) 后端配合 3.接口代理 ... 查看详情

三种跨域解决方案(代码片段)

当前端页面与后台运行在不同的服务器时,就必定会出现跨域这一问题,本篇简单介绍解决跨域的三种方案,部分代码截图如下,仅供参考:Nginx代理这种方式比较简单,将A应用和B应用都通过一个统一的地址进行转发,这样就... 查看详情

跨域问题

当前端页面与后台运行在不同的服务器时,就必定会出现跨域这一问题,本篇简单介绍解决跨域的三种方案,部分代码截图如下,仅供参考:方式一:使用ajax的jsonp前端代码 服务器代码 使用该方式的缺点:请求方式只能... 查看详情

前端跨域的解决方式

前端与服务端数据交互时,涉及到跨域的一些问题。JavaScript出于安全的考虑,禁止了跨域调用其他页面的对象,也即同源策略限制了一个源(origin)中加载文本或脚本与来自其它源(origin)中资源的交互方式。什么是跨域?如... 查看详情

相关前台跨域的解决方式(代码片段)

title:前端跨域处理方式date:2018-07-0800:37:29categories:Web前端tags:跨域cors关于跨域请求解觉方案问题关于浏览器跨域问题,项目中也遇到了,看了项目上一些代码的处理方式,感觉存在不少不大完善的地方,因此对于跨域,想好好梳... 查看详情

跨域_解决浏览器跨域的方式

这里介绍的是--disable-web-security参数。这个参数可以降低chrome浏览器的安全性,禁用同源策略,利于开发人员本地调试。(1)新建一个chrome快捷方式,右键“属性”,“快捷方式”选项卡里选择“目标”,添加&... 查看详情

解决浏览器跨域的几种方式

  1、什么是跨域问题  在页面中使用js访问其他网站的数据时,就会出现跨域问题,比如在网站中使用ajax请求其他网站的天气、快递或者其他数据接口时,以及hybridapp中请求数据,浏览器会提  示一下错误... 查看详情

spring跨域的解决方式

...果这些方法用了都不行,还是出现状态码200但是还是出现跨域的错误:AccesstoXMLHttpRequestat'目标url'fromorigin'源url'hasbeenblockedbyCORSpolicy:No'Access-Control-Allow-Origin'headerispresentontherequestedresource.那么可能是被浏览器禁止... 查看详情

跨域请求的三种解决(代码片段)

第一种:jsonp的方式<?phpheader(‘Content-type:application/json‘);//获取回调函数名$jsoncallback=$_GET[‘jsoncallback‘];//json数据$json_data=‘"data":["did":"29","deptName":"u8f6fu4ef6u90e8","did":"30","deptName":"u8f6fu4ef6u90e8","did":"31","deptName":"u6d4bu8bd5u90e8","did"... 查看详情

解决geoserver请求跨域的几种思路

1.背景描述    跨域问题是浏览器同源安全制引起的特别常见的问题。不同前端语言针对跨域解决方法有所区别。比如Flex语言做跨域请求时,如果中间件存有跨域文件(crossdomain.xml)则可以轻松实现跨域。  ... 查看详情

centos软件安装的三种方式

Linux下面安装软件的常见方法:1.yum替你下载软件替你安装替你解决依赖关系点外卖缺少的东西外卖解决1).方便简单2)没有办法深入修改yuminstall-ytree2.rpm自己下载软件包自己安装自己解决依赖半成品缺少的东西自己解决1)安装解决依... 查看详情

依靠前端解决跨域问题的几种方式

首先我们先了解下跨域的概念:  出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建... 查看详情

跨域请求的方式即实现(代码片段)

跨域请求的三种方式解决方法前后端配合;jsonp;CORS–跨域资源共享Php服务器代理跨域请求的方式即实现浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域当发送方地址和接受放地... 查看详情

cors跨域的限制与解决

CORS跨域的限制与解决对于跨域的理解跨域行为是浏览器行为,一个跨域请求实际已经发送到服务端,服务端也返回了消息,然而浏览器在接收到返回信息的时候,发现该信息不是同源请求且没有允许跨域的限制,所以在解析消... 查看详情

vue中遇到跨域问题(代码片段)

昨天在vue开发项目中遇到一个坑,遇到了vue的跨域问题,通过多次度娘的查询,最终解决了这个问题,具体情形如下:新的项目,需要vue的开发,在本地的开发中遇到跨域的问题!vue中解决跨域问题的三种方法:1.服务器端添加... 查看详情

解决跨域的方式(9种)(代码片段)

 1.jsonp1)JSONP原理利用<script>标签没有跨域限制的漏洞,网页可以得到从其他来源动态产生的JSON数据。JSONP请求一定需要对方的服务器做支持才可以。2)JSONP和AJAX对比JSONP和AJAX相同,都是客户端向服务器端发送请求,从服务... 查看详情

求助关于chrome跨域的问题

参考技术Ajsonp能使用的前提是跨域地址给你提供了访问方式,就像你不可以直接请求baidu地址一样,百度又没有给你提供这样的服务,一般解决跨域问题, 查看详情