跨域(CORS)問(wèn)題的解決方案分享
前后端分離項(xiàng)目,如何解決跨域問(wèn)題
跨域資源共享(CORS)是前后端分離項(xiàng)目很常見(jiàn)的問(wèn)題,本文主要介紹當(dāng)SpringBoot應(yīng)用整合SpringSecurity以后如何解決該問(wèn)題。
什么是跨域問(wèn)題
CORS全稱(chēng)Cross-Origin Resource Sharing,意為跨域資源共享。當(dāng)一個(gè)資源去訪問(wèn)另一個(gè)不同域名或者同域名不同端口的資源時(shí),就會(huì)發(fā)出跨域請(qǐng)求。如果此時(shí)另一個(gè)資源不允許其進(jìn)行跨域資源訪問(wèn),那么訪問(wèn)的那個(gè)資源就會(huì)遇到跨域問(wèn)題。
跨域問(wèn)題演示及解決
我們使用mall項(xiàng)目的源代碼來(lái)演示一下跨域問(wèn)題。此時(shí)前端代碼運(yùn)行在8090端口上,后端代碼運(yùn)行在8080端口上,由于其域名都是localhost,但是前端和后端運(yùn)行端口不一致,此時(shí)前端訪問(wèn)后端接口時(shí),就會(huì)產(chǎn)生跨域問(wèn)題。
點(diǎn)擊前端登錄按鈕
此時(shí)發(fā)現(xiàn)調(diào)用登錄接口時(shí)出現(xiàn)跨域問(wèn)題。

覆蓋默認(rèn)的CorsFilter來(lái)解決該問(wèn)題
添加GlobalCorsConfig配置文件來(lái)允許跨域訪問(wèn)。
package com.macro.mall.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;
/**
* 全局跨域配置
* Created by macro on 2019/7/27.
*/
@Configuration
public class GlobalCorsConfig {
/**
* 允許跨域調(diào)用的過(guò)濾器
*/
@Bean
public CorsFilter corsFilter() {
CorsConfiguration config = new CorsConfiguration();
//允許所有域名進(jìn)行跨域調(diào)用
config.addAllowedOrigin("*");
//允許跨越發(fā)送cookie
config.setAllowCredentials(true);
//放行全部原始頭信息
config.addAllowedHeader("*");
//允許所有請(qǐng)求方法跨域調(diào)用
config.addAllowedMethod("*");
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
source.registerCorsConfiguration("/**", config);
return new CorsFilter(source);
}
}或者使用這個(gè)配置類(lèi)
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class CorsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOriginPatterns("*")
.allowCredentials(true)
.allowedMethods("GET", "POST", "DELETE", "PUT", "PATCH")
.maxAge(3600);
}
}重新運(yùn)行代碼,點(diǎn)擊登錄按鈕
發(fā)現(xiàn)需要登錄認(rèn)證的/admin/info接口的OPTIONS請(qǐng)求無(wú)法通過(guò)認(rèn)證,那是因?yàn)閺?fù)雜的跨越請(qǐng)求需要先進(jìn)行一次OPTIONS請(qǐng)求進(jìn)行預(yù)檢,我們的應(yīng)用整合了SpringSecurity,對(duì)OPTIONS請(qǐng)求并沒(méi)有放開(kāi)登錄認(rèn)證。

設(shè)置SpringSecurity允許OPTIONS請(qǐng)求訪問(wèn)
在SecurityConfig類(lèi)的configure(HttpSecurity httpSecurity)方法中添加如下代碼。
.antMatchers(HttpMethod.OPTIONS)//跨域請(qǐng)求會(huì)先進(jìn)行一次options請(qǐng)求 .permitAll()

重新運(yùn)行代碼,點(diǎn)擊登錄按鈕
發(fā)現(xiàn)已經(jīng)可以正常訪問(wèn)。

一次完整的跨域請(qǐng)求
先發(fā)起一次OPTIONS請(qǐng)求進(jìn)行預(yù)檢
- 請(qǐng)求頭信息:
Access-Control-Request-Headers: content-type Access-Control-Request-Method: POST Origin: http://localhost:8090 Referer: http://localhost:8090/ User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36
- 響應(yīng)頭信息:
Access-Control-Allow-Credentials: true Access-Control-Allow-Headers: content-type Access-Control-Allow-Methods: POST Access-Control-Allow-Origin: http://localhost:8090 Cache-Control: no-cache, no-store, max-age=0, must-revalidate Content-Length: 0 Date: Sat, 27 Jul 2019 13:40:32 GMT Expires: 0 Pragma: no-cache Vary: Origin, Access-Control-Request-Method, Access-Control-Request-Headers X-Content-Type-Options: nosniff X-Frame-Options: DENY X-XSS-Protection: 1; mode=block
- 請(qǐng)求成功返回狀態(tài)碼為200
發(fā)起真實(shí)的跨域請(qǐng)求
- 請(qǐng)求頭信息:
Accept: application/json, text/plain
Content-Type: application/json;charset=UTF-8
Origin: http://localhost:8090
Referer: http://localhost:8090/
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36
{username: "admin", password: "123456"}
password: "123456"
username: "admin"- 響應(yīng)頭信息:
Access-Control-Allow-Credentials: true Access-Control-Allow-Origin: http://localhost:8090 Cache-Control: no-cache, no-store, max-age=0, must-revalidate Content-Type: application/json;charset=UTF-8 Date: Sat, 27 Jul 2019 13:40:32 GMT Expires: 0 Pragma: no-cache Transfer-Encoding: chunked Vary: Origin, Access-Control-Request-Method, Access-Control-Request-Headers X-Content-Type-Options: nosniff X-Frame-Options: DENY X-XSS-Protection: 1; mode=block
- 請(qǐng)求成功返回狀態(tài)碼為200
到此這篇關(guān)于跨域(CORS)問(wèn)題的解決方案分享的文章就介紹到這了,更多相關(guān)解決跨域(CORS)問(wèn)題內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
dell r710 服務(wù)器配置RAID5(3塊硬盤(pán)做RAID5)
這篇文章主要介紹了dell r710 服務(wù)器配置RAID5圖文教程,需要的朋友可以參考下2014-08-08
LVS(Linux Virtual Server)Linux 虛擬服務(wù)器介紹及配置(負(fù)載均衡系統(tǒng))
LVS(Linux Virtual Server) 是Unix-like系統(tǒng)中的一個(gè)虛擬服務(wù)器,是國(guó)內(nèi)貢獻(xiàn)給開(kāi)源組織的一個(gè)最優(yōu)秀的項(xiàng)目之一2012-05-05
教你安裝磁盤(pán)陣列:組建RAID需要幾塊硬盤(pán)
這篇文章主要為大家分享下如何安裝磁盤(pán)陣列,同時(shí)介紹了不用陣列的區(qū)別與應(yīng)用范圍,需要的朋友可以參考下2014-05-05
輕量級(jí)域名解析服務(wù)器之dnsmasq的介紹與部署
dnsmasq這個(gè)輕量級(jí)的dns服務(wù)器,具有開(kāi)源,搭建簡(jiǎn)單,維護(hù)成本低的優(yōu)點(diǎn),符合生產(chǎn)環(huán)境需求,下面這篇文章主要給大家介紹了關(guān)于輕量級(jí)域名解析服務(wù)器之dnsmasq的介紹與部署的相關(guān)資料,需要的朋友可以參考下2022-07-07
k8s監(jiān)控?cái)?shù)據(jù)組件Pod自動(dòng)化進(jìn)行擴(kuò)縮容HPA
這篇文章主要為大家介紹了監(jiān)控?cái)?shù)據(jù)組件Pod自動(dòng)化進(jìn)行擴(kuò)縮容-HPA的全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03
win10 docker-toolsbox 搭建php開(kāi)發(fā)環(huán)境的教程
這篇文章主要介紹了win10 docker-toolsbox 搭建php開(kāi)發(fā)環(huán)境的教程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-10-10

