国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Spring Cloud項目前后端分離跨域的操作

瀏覽:8日期:2023-07-06 13:26:14
跨域問題,其實百度上面有一堆的解決方案

針對普通的情況其實百度上面的方案都是可行的。

我這里主要介紹2種情況。

當然我這里的配置都是基于網關的,而不是基于服務的。

1、沒有增加權限驗證。

2、增加了spring security的權限驗證(我這里是基于keyCloak),增加了Authorization

首先我們介紹第一種情況的解決方法,這個很簡單,只需要在啟動類里面配置過濾器就可以解決。

@Bean public CorsFilter corsFilter() {//1.添加CORS配置信息CorsConfiguration config = new CorsConfiguration(); //放行哪些原始域 config.addAllowedOrigin('*'); //是否發送Cookie信息 config.setAllowCredentials(true); //放行哪些原始域(請求方式) config.addAllowedMethod('*'); //放行哪些原始域(頭部信息) config.addAllowedHeader('*'); //暴露哪些頭部信息(因為跨域訪問默認不能獲取全部頭部信息) config.addExposedHeader('*'); //2.添加映射路徑UrlBasedCorsConfigurationSource configSource = new UrlBasedCorsConfigurationSource();configSource.registerCorsConfiguration('/**', config); //3.返回新的CorsFilter.return new CorsFilter(configSource); }

我遇到情況就是第二種了,這種情況上面的方式基本沒有作用,我這里使用的是keyCloak做的權限驗證。

首先增加過濾器配置:

@Componentpublic class CorsControllerFilter implements Filter{@Overridepublic void destroy() {// TODO Auto-generated method stub} @Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {// TODO Auto-generated method stubHttpServletResponse res = (HttpServletResponse) response;res.setContentType('text/html;charset=UTF-8');res.setHeader('Access-Control-Allow-Origin', '*');res.setHeader('Access-Control-Allow-Methods', 'POST, GET, OPTIONS, DELETE ,PUT');res.setHeader('Access-Control-Max-Age', '3600');res.setHeader('Access-Control-Allow-Headers', '*');res.setHeader('Access-Control-Allow-Credentials', 'true');res.setHeader('XDomainRequestAllowed', '1');chain.doFilter(request, response);} @Overridepublic void init(FilterConfig arg0) throws ServletException {// TODO Auto-generated method stub}}

在啟動類中增加配置

@Bean public FilterRegistrationBean filterRegistrationBean() { FilterRegistrationBean registrationBean = new FilterRegistrationBean(); CorsControllerFilter corsControllerFilter = new CorsControllerFilter(); registrationBean.setFilter(corsControllerFilter); return registrationBean; }

但是針對某些請求,他會先請求OPTIONS請求,造成權限驗證失敗。所以增加攔截器配置,對所有的OPTIONS的請求直接放行,返回200的狀態。

public class OptionsInterceptor implements HandlerInterceptor { @Overridepublic void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)throws Exception {// TODO Auto-generated method stub} @Overridepublic void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)throws Exception {// TODO Auto-generated method stub} @Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {// TODO Auto-generated method stubif(request.getMethod().equals('OPTIONS')){ response.setStatus(HttpServletResponse.SC_OK); return false;}return true;}}

配置web配置文件,加載攔截器。

@Configurationpublic class WebMvcConfiguration extends WebMvcConfigurationSupport{ @Override public void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new OptionsInterceptor()).addPathPatterns('/**'); }}

本來以為這樣配置了應該是可以了,但是在請求的時候OPTIONS的請求居然還是報跨域的問題,增加攔截器允許跨域配置

public class CrossInterceptor implements HandlerInterceptor{ @Override public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) throws Exception { // TODO Auto-generated method stub } @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3) throws Exception { // TODO Auto-generated method stub } @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // TODO Auto-generated method stubresponse.setHeader('Access-Control-Allow-Origin', '*');response.setHeader('Access-Control-Allow-Credentials', 'true');response.setHeader('Access-Control-Allow-Methods', 'POST, GET, OPTIONS, DELETE, PUT, HEAD');response.setHeader('Access-Control-Allow-Headers', '*');response.setHeader('Access-Control-Max-Age', '3600');return true; }}

在WebMvcConfiguration里面增加配置,注意要寫在OptionsInterceptor的前面

registry.addInterceptor(new CrossInterceptor()).addPathPatterns('/**');

繼續測試,跨域問題解決。對于原理其實我也不太清楚,歡迎各位溝通交流。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 美女黄影院 | 成人免费久久精品国产片久久影院 | 欧美在线成人午夜网站 | 成年美女黄网站色视频大全免费 | 亚洲国产精品二区久久 | 欧美黄网在线 | 大香伊蕉国产短视频69 | 在线观看精品视频一区二区三区 | 久久免费小视频 | 激情一区二区三区成人 | 亚洲精品国产福利 | 一区二区精品视频 | 免费观看国产精品 | 一区二区三区在线免费观看视频 | 欧美高清在线视频一区二区 | 成人无遮挡毛片免费看 | 欧美日韩在线永久免费播放 | 日韩二区三区 | 国产区精品在线 | 亚洲天堂免费在线视频 | www.日本在线观看 | 日韩欧美在线观看一区 | 国产精品日产三级在线观看 | 国产精品久久网 | 久久国产精品久久国产片 | 免费va国产高清不卡大片 | 欧美成人做爰网站 | 国产精品免费一区二区三区 | 国产成人亚洲精品老王 | 99er精品 | 爱爱客影院在线影院gf发现 | 亚洲精彩视频在线观看 | 精品日本久久久久久久久久 | 91久久精品国产91久久性色也 | 国产精品久久久久久久9999 | 5388国产亚洲欧美在线观看 | 国产成人3p视频免费观看 | 性做久久久久久久免费观看 | 国产乱码一区二区三区四川人 | 国产精品高清视亚洲一区二区 | 美女视频网站永久免费观看软件 |