0-前言
前后端分離、分布式集群,經常都會涉及到跨域訪問,而瀏覽器基於同源策略,正常情況下是不能跨域的,這就需要我們解決跨域訪問問題;spring boot解決跨域也比較簡單;
1-CORS跨域解決方案
spring boot CORS解決跨域比較簡單,只需要增加一個CORS的配置類即可;在config下新建一個配置類,代碼如下:
package com.anson.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
/**
* @description: CORS跨域配置類
* @author: anson
* @Date: 2019/9/5 14:54
* @version: 1.0
*/
@Configuration
public class CORSConfiguration extends WebMvcConfigurationSupport
{
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedMethods("GET", "POST", "DELETE", "PUT","PATCH")
.allowedOrigins("*")
.maxAge(3600)
.allowCredentials(true)
.allowedHeaders("*");
super.addCorsMappings(registry);
}
}
完成,這樣就可以跨域訪問了,上面的參數簡要解釋下:
addMapping:配置可以被跨域的路徑,可以任意配置,可以具體到直接請求路徑。
allowedMethods:允許所有的請求方法訪問該跨域資源服務器,如:POST、GET、PUT、DELETE等。
allowedOrigins:允許所有的請求域名訪問我們的跨域資源,可以固定單條或者多條內容,如:“http://www.aaa.com”,只有該域名可以訪問我們的跨域資源。
allowedHeaders:允許所有的請求header訪問,可以自定義設置任意請求頭信息。
附一篇介紹得詳細一點的博文:https://www.cnblogs.com/anxminise/p/9808279.html
源碼地址:https://github.com/anson-yang/cloverDemo.git
