前端跨域的几种解决方式总结(推荐)

作者&投稿:郅建 (若有异议请与网页底部的电邮联系)
~

搞大前端的,肯定都会遇到跨域问题的,虽然网上这方面的资料也很多,但我还是喜欢自己写一遍,自己理解过、总结过的东西才记得最深刻。

同源策略

JavaScript 的同源策略,是由Netscape提出的一个著名的安全策略,为了阻止A站的JS去操作别的网站的数据。你想啊,你现在打开了浏览器,在一个tab窗口中打开了银行网站,在另外一个tab窗口中打开了一个恶意网站,而那个恶意网站挂了一个的专门修改银行信息的JavaScript,当你访问这个恶意网站并且执行它JavaScript时,你的银行页面就会被这个JavaScript修改(比如说获取你的卡号和密码,又或者是转账到黑客的账户上等等),后果会非常严重!而同源策略就为了防止这种事情发生,它规定了A网站下的JS文件只能操作A网站下的数据,不能去操作B网站的数据。

为了方便理解,我们把这个词拆分成同源和策略这2个词吧(原谅我,我就怕你不理解啊)。

所谓同源指的就是指资源是来自同一个源的。如果两个页面拥有相同的协议,端口号,和主机(包括子域名和主域名),那么这两个页面就属于同一个源。

所谓策略指的是可以做什么事情。同一个源下的JS可以操作同一个源下的数据。

举个例子来看看你理解了没有吧,看下面这个链接,协议是http协议,主机是store.company.com,端口号一般默认的都是80了。然后和下面的这个表中的各个URL进行比较,判断一下哪些是同源的,哪些不是同源的。



URL
结果
原因




http://store.company.com/dir2/other.html
同源



http://store.company.com/dir/inner/another.html
同源



https://store.company.com/secure.html
非同源
协议不同


http://store.company.com:81/dir/etc.html
非同源
端口不同


http://news.company.com/dir/other.html
非同源
主机不同




什么是跨域

跨域



跨域的解决方案

方案1-JSONP

JSONP是JSON with padding的简写。JSONP由两部分组成:回调函数和数据。

回调函数是客户端和服务端约定好一个函数名,一般在请求中指定。

数据是传入回调函数中的JSON数据。

JSONP是通过动态的

callback({"name": "michael"});

问题一:JSONP是需要动态创建script标签的,我们需不需要处理这些script元素?怎么处理?

问题二:JSONP请求的时候,服务器发生错误该怎么办,比如服务器崩掉,比如返回了404页面,前端该怎么处理这个错误,难道直接让它抛出么?

答案

JSONP只能实现GET请求,而CORS支持所有类型的HTTP请求

JSONP的兼容性好,不需要XMLHttpRequest的支持

方案2-跨域资源共享CORS

跨域资源共享定义了在必须访问跨域资源的时,浏览器与服务器应该如何沟通。他的原理是使用自定义的 HTTP 头部,让服务器与浏览器进行沟通,主要是通过设置响应头的 Access-Control-Allow-Origin 来达到目的的。

方案3-document.domain

浏览器的同源策略使得不同域的框架是不能进行JS的交互操作的。比如:有一个页面是http://www.examples.com/a.htmls,在这个页面中还有一个http://examples.com/b.htmls,很显然,a.html与b.html是不同域的,所以我们无法通过在页面中书写js代码来获取iframe中的东西,但是,如果我们把这2个页面的document.domain都设置成相同的域名就可以了,需要注意的是,我们只能把document.domain设置成自身或更高一级的父域,且主域名必须相同。

使用条件

document.domain适用于不同子域的框架之间的交互。

方案4-window.name

window对象有个name属性,该属性有一个特征:即在一个窗口的生命周期内,窗口载入的所有页面都是共享一个window.name的,每个页面对window.name都有读写的权限,window.name是持久存在一个窗口载入过的所有页面中的。

方案5-window.postMessage

window.postMessage(message,targetOrigin)方法,可以用来向其他的window对象发送消息,无论这个window对象是属于同一个源还是不同源




nginx怎么解决跨域
Nginx可以通过设置HTTP响应头来解决跨域问题。跨域问题主要是由于浏览器的同源策略导致的,它限制了不同域名之间的资源访问。为了解决这个问题,可以在Nginx的配置文件中设置HTTP响应头,允许跨域访问。具体解决方法如下:1. 添加跨域头部信息:在Nginx的配置文件中,可以通过添加`add_header`指令来设置HTTP响应...

跨域有哪几种方式
1. 通过jsonp跨域 2. document.domainiframe跨域 3. nginx代理跨域 4. nodejs中间件代理跨域 5. 后端在头部信息里面设置安全域名

跨域的几种方法
而有时候,我们不得不在一个客户端下访问不同域中的资源,于是需要用到一些方法来避开浏览器的同源策略,这些方法被称为跨域。实现跨域有如下几种方法:JSONP(JSON with Padding)是数据格式JSON的一种使用模式,可以使网页实现跨域请求。其原理主要利用了 HTML 的 script 标签。由于 script 是采用...

三种解决 react 跨域问题的方法
三种解决React跨域问题的实践方法在React应用中,跨域问题常常遇到,以下是三种常见的处理策略:首先,你可以在当前文件所在的目录下,在package.json文件中进行配置。只需在文件中添加适当的CORS相关设置,比如允许特定的HTTP方法,尽管接口的具体路径可以更换,但方法的选择至关重要。另一种方法是在src目录下...

解决浏览器访问本地文件跨域问题
为解决这一问题,有几种可行的途径:最直接的方法是将你的代码部署到远程服务器上,这样浏览器就不会再认为请求是跨域的。如果你使用的是Visual Studio Code(VSCode),可以利用其Live Server插件,通过该插件运行和访问本地文件,避免跨域问题。如果暂时需要在本地测试,可以临时更改浏览器设置。在浏览器...

跨域是指什么,因为什么引起的?有哪些解决方案?web前端知识
有一种简明的说法来解释广域跨域:跨域访问,简单来说就是 A 网站的 javascript 代码试图访问 B 网站,包括提交内容和获取内容。由于安全原因,跨域访问是被各大浏览器所默认禁止的。解决方案:1、js向服务器发送请求,然后让服务器去另一个域上获取数据后返回。(用于你无法控制另一个域) 比如php中...

浏览器跨域及其解决方案
什么是跨域跨域的表现解决跨域问题- 浏览器设置(不推荐)- 前端的非正统解决方式- CORS(跨域资源共享)- 配置nginx反向代理 跨域 出于浏览器的同源策略限制, 同源 是指协议、域名、端口都一样, 同源策略(Sameoriginpolicy) 是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则...

同源策略与跨域解决方案
使用过滤器或拦截器可以实现更复杂的CORS支持,适应特定需求。在使用Spring Security时,可启用CORS功能,确保安全性和跨域请求兼容性。使用代理服务,可以将不同的接口请求整合至同一域名下,从而避免跨域问题。综上所述,同源策略和CORS解决方案提供了安全和灵活性,确保跨域访问在web开发中的有效管理和控制。

跨域(Options)请求介绍及解决方法
在实际应用中,我们可能会遇到一个现象:只有在进行跨域请求时,浏览器才会自动发送OPTIONS请求。这是由于浏览器为了确保安全,会对非同源(不同域名)的服务器进行权限验证,防止未经授权的自定义头信息传递。避免OPTIONS请求的方法有几种。首先,可以在网关层面设置转发规则,消除跨域影响。其次,可以将需要...

React解决跨域的方法
跨域问题在前端开发中是常见难题,React也难以避免。为了解决跨域问题,有以下两种方法:proxy配置和setupProxy配置。第一种方法是proxy配置,其主要是在package.json文件中实现。这种方式的优点是设置简单,前端发起请求时无需添加任何前缀。然而,缺点也很明显,即无法配置多个代理。第二种方法是setupProxy配置...

合阳县17544734031: 如何解决跨域问题 -
房阅加味: 关于跨域名问题还是问题么,这方面的解决实践非常多,今天我就旧话重提把我所知道的通过几个应用场景来分别总结一下(转帖请注明出处:http://blog.csdn.net/lenel) 先说明一点:我说的某某域名在您的控制下的意思是这个域名下的网页由...

合阳县17544734031: 前端设置请求头可以解决跨域问题吗 -
房阅加味: 不可以.解决跨越常用的几种方法.1、jsonp传输.2、代理.3、CORS,也就是常用的让服务端设置Access-Control-Allow-Origin:* 或者是Access-Control-Allow-Origin:允许的域名.

合阳县17544734031: 前端请求接口出现跨域问题怎么解决 -
房阅加味: 1. 使用jsonp 2. 响应头增加CORS跨域响应的信息 3. 服务器(同域内的)做一次转发

合阳县17544734031: 如何解决js跨域问题 -
房阅加味: js跨域解决方法:1. 使用jsonp方式跨域,支持GET,不支持POST2. 服务器端一个跨域头,使用CORS方式进行跨域3. iframe通过参数或hash跨域4. postMessage跨域5. 其他方式

合阳县17544734031: 跨域是指什么,因为什么引起的?有哪些解决方案?web前端知识 -
房阅加味: 域(Domain)是Windows网络中独立运行的单位,域之间相互访问则需要建立信任关系(即Trust Relation).信任关系是连接在域与域之间的桥梁.当一个域与其他域建立了信任关系后,2个域之间不但可以按需要相互进行管理,还可以跨网分...

合阳县17544734031: 用ajax怎么解决跨域的问题? -
房阅加味: 解决的办法,有如下几种:<br>1. 使用中间层过渡的方式(可以理解为“代理”):<br> 中间过渡,很明显,就是在AJAX与不同域的服务器进行通讯的中间加一层过渡,这一层过渡可以是PHP、JSP、c++等任何具备网络通讯功能的语言,由中...

合阳县17544734031: vue - cli与后台给的接口有跨域.跨域怎么配置 -
房阅加味: 跨域问题来源于JavaScript的同源策略,即只有协议+主机名+端口号(如存在)相同,则允许相互访问.也就是说JavaScript只能访问和操作自己域下的资源,不能访问和操作其他域下的资源.在以前,前端和后端混杂在一起,比如JavaScript直...

合阳县17544734031: ajax 跨域的几种解决办法 -
房阅加味: JSONP JSONP是JSON with Padding的略称.它是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问(这仅仅是JSONP简单的实现形式).关于jsonp的使用方式,可以参考http://...

合阳县17544734031: JSP ajax跨域问题 怎么处理 原因 -
房阅加味: 如果是ajax的GET可以跨域的,这个如果是jQuery技术可以使用type:json. 但是如果是ajax的POST请求是不可以跨域的,上次看到.net的一个可以使用flash完成跨域.

合阳县17544734031: Nginx解决前端跨域问题 CORS跨域配置? -
房阅加味: Nginx的CORS配置,网上太多这配置了,但大家更多的复制粘贴、转发,几乎都是类似下面这三两行: add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With; add_header Access-Control-Allow-Methods GET,POST,OPTIONS;这样有用么?有用,我以前这样使用也正常过,但后来还是遇到问题了,发现有些项目请求就不成功,也遇到有些浏览器成功,有些浏览器不成功; 参考 Nginx解决前端跨域问题 linux部署配置nginx.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网