跨域:域名或者端口不同,就是跨域
跨域问题概述:浏览器禁止请求的发送者与服务端发生跨域ajax请求,于是请求被浏览器拦截的问题。
解决方案:ajax通过cros解决跨域问题,即每次请求前会向目标服务器询问是否允许自己请求,若服务器允许,则浏览器不会拦截本次请求。所以我们只需在服务端设置允许跨域请求的配置即可。下面介绍Gateway框架的配置方法。在application.yml中配置以下信息即可:
spring:
cloud:
gateway:
globalcors: # 全局的跨域处理
add-to-simple-url-handler-mapping: true # 因为ajax发起者会通过options请求来向服务器询问是否允许跨域,所以需要设置为true来解决options请求被拦截问题
corsConfigurations:
'[/**]':
allowedOrigins: # 允许哪些网站的跨域请求
- "http://localhost:8090"
allowedMethods: # 允许的跨域ajax的请求方式
- "GET"
- "POST"
- "DELETE"
- "PUT"
- "OPTIONS"
allowedHeaders: "*" # 允许在请求中携带的头信息
allowCredentials: true # 是否允许携带cookie
maxAge: 360000 # 这次跨域检测的有效期,即一定时间内就不需要重复询问是否允许跨域了,直接请求即可。