目录

  • 跨域概念
  • 跨域场景
  • 协议不同
  • IP不同
  • 端口号不同
  • 跨域存在必要性
  • 如何解决
  • 前端解决
  • 后端解决


跨域概念

协议,IP,端口号。

三者有一个不同,就存在跨域行为。

跨域场景

协议不同

HTTP、HTTPS协议。

IP不同

你在本地跑你的前端项目,访问阿里云上的后台项目,两个ip不一样,存在跨域问题。

端口号不同

比如前后端分离项目

前端 localhost:8080

后端 localhost:8090

在前端页面,在localhost:8080里边,我要访问别的域localhost:8090,就存在跨域问题。

跨域存在必要性

同源策略,是浏览器最基础的最核心的安全功能。

同源策略,限制了A源与B源之间的数据交互。

如果没有同源策略,浏览器很容易受到XSS、CSFR等攻击。

我举个例子。

以登录来说明跨域存在的必要性。

登录一个商城后,服务端会在响应头加入Set-Cookies字段,然后下次访问服务端的时候,请求头中就会带着这个cookies,表明已经登录过,可以正常访问。

在没有同源策略的情况下,如果此时页面上跳出来了一个非法链接,你点进去了,这个非法链接就可以获取你的cookies信息,之后用你的账号疯狂买买买。

在有同源策略的情况下,商城的源与非法链接的源是不可以进行数据交互的,非法链接没办法获取你的信息。

如何解决

前端解决

使用Nginx配置反向代理解决跨域问题。

nginx一大重点功能就是反向代理。

比如:

前端项目:localhost:8080

后端项目:localhost:8090

现在localhost:8080里边,访问8090端口,产生了跨域问题。

在8080里边,只能访问8080的东西,那么我就让nginx时刻监听着8080端口号,然后将来自8080的请求,根据不同的location,代理向8090服务器。

由nginx代理服务器,帮你访问8090端口,然后获取返回数据,再传给你8080,nginx帮你解决了8080直接访问8090产生的跨域问题,那么问题来了,nginx怎么实现的这个功能呢?俺也不知道。

后端解决

使用CORS跨域资源共享解决跨域问题。

前提条件:

CORS通信需要浏览器和服务器端共同进行配合。

浏览器端不用你管,只要不是IE10以下,浏览器默认支持CORS通信。

所以你需要做的就是在服务器端进行处理。

思路和实现:

明确一点:CORS本质就是对请求头和响应头进行处理。

浏览器自己会在请求头里边加入一些信息,请求头里本身就包括,比如Origin,Access-Control-Request-Headers等。服务器根据自己配置的跨域规则对这些信息进行判断,是否允许其进行跨域,若允许,在访问完成后,服务响应的时候,再在头里边加入一些信息。加入什么信息呢,响应头是有很多东西的,比如Access-Control-Allow-Credentials,Access-Control-Allow-Origin等。

比如在网关中,配置CORS配置类,在application.yml文件中,添加允许的源,允许的请求类型,

当浏览器发生跨域请求时,经过网关,使用spring mvc的CorsFilter,对源进行判断和处理,就可以成功完成数据的交互。

记住下边这两行代码就可以了。

一个是配置,配置允许哪些源,是否允许携带cookie,允许其你去的类型,允许头信息,有效期等内容。

一个是资源,对哪些资源(url,一般会使用/**表示所有资源)使用哪些配置(上边的配置)。

CorsConfiguration config = new CorsConfiguration();
 UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
 ojbk,cors解决跨域问题完成。