亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

更多QQ空间微信QQ好友腾讯朋友复制链接
您的位置:首頁/技術文章
文章詳情頁

Java 如何解決跨域問題

【字号: 作者:豬豬瀏覽:3日期:2022-08-16 08:23:02
引言

我們在開發(fā)過程中經常會遇到前后端分離而導致的跨域問題,導致無法獲取返回結果??缬蚓拖穹蛛x前端和后端的一道鴻溝,君在這邊,她在那邊,兩兩不能往來.

什么是跨域(CORS)

跨域(CORS)是指不同域名之間相互訪問??缬?,指的是瀏覽器不能執(zhí)行其他網站的腳本,它是由瀏覽器的同源策略所造成的,是瀏覽器對于JavaScript所定義的安全限制策略。

什么情況會跨域 同一協(xié)議, 如http或https 同一IP地址, 如127.0.0.1 同一端口, 如8080

以上三個條件中有一個條件不同就會產生跨域問題。

解決方案前端解決方案 使用JSONP方式實現跨域調用; 使用NodeJS服務器做為服務代理,前端發(fā)起請求到NodeJS服務器, NodeJS服務器代理轉發(fā)請求到后端服務器; 后端解決方案 nginx反向代理解決跨域 服務端設置Response Header(響應頭部)的Access-Control-Allow-Origin 在需要跨域訪問的類和方法中設置允許跨域訪問(如Spring中使用@CrossOrigin注解); 繼承使用Spring Web的CorsFilter(適用于Spring MVC、Spring Boot) 實現WebMvcConfigurer接口(適用于Spring Boot)具體方式一、使用Filter方式進行設置

使用Filter過濾器來過濾服務請求,向請求端設置Response Header(響應頭部)的Access-Control-Allow-Origin屬性聲明允許跨域訪問。

@WebFilterpublic class CorsFilter implements Filter { @Override public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { HttpServletResponse response = (HttpServletResponse) res; response.setHeader('Access-Control-Allow-Origin', '*'); response.setHeader('Access-Control-Allow-Methods', '*'); response.setHeader('Access-Control-Max-Age', '3600'); response.setHeader('Access-Control-Allow-Headers', '*'); response.setHeader('Access-Control-Allow-Credentials', 'true'); chain.doFilter(req, res); } }二、繼承 HandlerInterceptorAdapter

@Componentpublic class CrossInterceptor extends HandlerInterceptorAdapter { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { response.setHeader('Access-Control-Allow-Origin', '*'); response.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS'); response.setHeader('Access-Control-Max-Age', '3600'); response.setHeader('Access-Control-Allow-Headers', '*'); response.setHeader('Access-Control-Allow-Credentials', 'true'); return true; }}三、實現 WebMvcConfigurer

@Configuration@SuppressWarnings('SpringJavaAutowiredFieldsWarningInspection')public class AppConfig implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping('/**') // 攔截所有的請求.allowedOrigins('http://www.abc.com') // 可跨域的域名,可以為 *.allowCredentials(true).allowedMethods('*') // 允許跨域的方法,可以單獨配置.allowedHeaders('*'); // 允許跨域的請求頭,可以單獨配置 }}四、使用Nginx配置

location / { add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With; add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,OPTIONS; if ($request_method = ’OPTIONS’) { return 204; }}五、使用 @CrossOrgin 注解

如果只是想部分接口跨域,且不想使用配置來管理的話,可以使用這種方式

在Controller使用

@CrossOrigin@RestController@RequestMapping('/user')public class UserController {@GetMapping('/{id}')public User get(@PathVariable Long id) {}@DeleteMapping('/{id}')public void remove(@PathVariable Long id) {}}

在具體接口上使用

@RestController@RequestMapping('/user')public class UserController {@CrossOrigin@GetMapping('/{id}')public User get(@PathVariable Long id) {}@DeleteMapping('/{id}')public void remove(@PathVariable Long id) {}}Spring Cloud Gateway 跨域配置

spring: cloud: gateway: globalcors: cors-configurations: ’[/**]’: # 允許跨域的源(網站域名/ip),設置*為全部 # 允許跨域請求里的head字段,設置*為全部 # 允許跨域的method, 默認為GET和OPTIONS,設置*為全部 allow-credentials: true allowed-origins: - 'http://xb.abc.com' - 'http://sf.xx.com' allowed-headers: '*' allowed-methods: - OPTIONS - GET - POST - DELETE - PUT - PATCH max-age: 3600

注意: 通過gateway 轉發(fā)的其他項目,不要進行配置跨域配置

有時即使配置了也不會起作用,這時你可以根據瀏覽器控制的錯誤輸出來查看問題,如果提示是 response 中 header 出現了重復的 Access-Control-* 請求頭,可以進行如下操作

import java.util.ArrayList;import org.springframework.cloud.gateway.filter.GatewayFilterChain;import org.springframework.cloud.gateway.filter.GlobalFilter;import org.springframework.cloud.gateway.filter.NettyWriteResponseFilter;import org.springframework.core.Ordered;import org.springframework.http.HttpHeaders;import org.springframework.stereotype.Component;import org.springframework.web.server.ServerWebExchange;import reactor.core.publisher.Mono;@Component('corsResponseHeaderFilter')public class CorsResponseHeaderFilter implements GlobalFilter, Ordered { @Override public int getOrder() { // 指定此過濾器位于NettyWriteResponseFilter之后 // 即待處理完響應體后接著處理響應頭 return NettyWriteResponseFilter.WRITE_RESPONSE_FILTER_ORDER + 1; } @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { return chain.filter(exchange).then(Mono.defer(() -> { exchange.getResponse().getHeaders().entrySet().stream() .filter(kv -> (kv.getValue() != null && kv.getValue().size() > 1)) .filter(kv -> ( kv.getKey().equals(HttpHeaders.ACCESS_CONTROL_ALLOW_ORIGIN) || kv.getKey().equals(HttpHeaders.ACCESS_CONTROL_ALLOW_CREDENTIALS) || kv.getKey().equals(HttpHeaders.ACCESS_CONTROL_ALLOW_METHODS) || kv.getKey().equals(HttpHeaders.ACCESS_CONTROL_ALLOW_HEADERS) || kv.getKey().equals(HttpHeaders.ACCESS_CONTROL_MAX_AGE))) .forEach(kv -> { kv.setValue(new ArrayList<String>() {{ add(kv.getValue().get(0)); }}); }); return chain.filter(exchange); })); }}

以上就是Java 如何解決跨域問題的詳細內容,更多關于Java 解決跨域問題的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 精品视频久久久久 | 免费国产网站 | 制服丝袜第一页在线 | 一级大片网站 | 欧洲成人在线视频 | 国语自产拍在线观看7m | 久久免费国产精品一区二区 | 久久一本色系列综合色 | 国产高清在线观看视频 | 日韩中文字幕电影 | 欧美一级特黄毛片视频 | 精品一区二区久久久久久久网精 | 中文字幕一区二区三区在线不卡 | 手机看片国产免费现在观看 | 欧美顶级黄色大片免费 | 黄网站免费在线 | 亚洲黑人巨大videos0 | 99在线视频精品 | 亚洲一区区 | 日本九九精品一区二区 | 蕾丝视频www在线观看 | 欧美精品在线免费观看 | 久久黄网 | 欧美日韩中文字幕在线 | 亚洲国产精品区 | 8050午夜一级全黄毛片 | 国产亚洲精品久久久久91网站 | 手机在线观看黄色网址 | 凹凸69堂国产成人精品视频 | 久久成人精品 | 国产日韩欧美中文 | 成人三级精品视频在线观看 | 欧美久久久久久久一区二区三区 | 日韩 欧美 国产 亚洲 中文 | 9久9久女女热精品视频免费观看 | 一道精品视频一区二区三区图片 | 美女被啪全免视频软件 | 精品国产自在现线看久久 | 色综合亚洲综合网站综合色 | 性欧美一级毛片欧美片 | 国产一区视频在线免费观看 |