最新springboot解決跨域的幾種方式小結
什麼是跨域
跨域:指的是瀏覽器不能執⾏其他⽹站的腳本。它是由瀏覽器的同源策略造成的,是瀏覽器對javascript施加的安全限制。
例如:a頁⾯想獲取b頁⾯資源,如果a、b頁⾯的協議、域名、端⼝、⼦域名不同,所進⾏的訪問⾏動都是跨域的,⽽瀏覽器
為瞭安全問題⼀般都限制瞭跨域訪問,也就是不允許跨域請求資源。註意:跨域限制訪問,其實是瀏覽器的限制。理解這⼀點
很重要
同源策略:是指協議,域名,端⼝都要相同,其中有⼀個不同都會產⽣跨域;
springboot解決跨域的幾種方式
方法一、SpringBoot的註解@CrossOrigin
直接在Controller方法或者類上增加@CrossOrigin註解,SpringMVC使用@CrossOrigin使用場景要求 jdk1.8+ Spring4.2+
@GetMapping("/hello") @CrossOrigin public String hello() { return "hello:" + simpleDateFormat.format(new Date()); }
方式二:使用CorsFilter
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; @Configuration public class ConfigConfiguration { @Bean public CorsFilter CorsFilter() { CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOriginPattern("*"); corsConfiguration.addAllowedHeader("*"); corsConfiguration.addAllowedMethod("*"); corsConfiguration.setAllowCredentials(true); UrlBasedCorsConfigurationSource ub = new UrlBasedCorsConfigurationSource(); ub.registerCorsConfiguration("/**", corsConfiguration); return new CorsFilter(ub); } }
方式三:自定義過濾(web filter)的方式
@Component public class CustomFilter implements Filter { @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletResponse res = (HttpServletResponse) servletResponse; // 設置允許Cookie res.addHeader("Access-Control-Allow-Credentials", "true"); // 允許http://www.xxx.com域(自行設置,這裡隻做示例)發起跨域請求 res.addHeader("Access-Control-Allow-Origin", "*"); // 設置允許跨域請求的方法 res.addHeader("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT"); // 允許跨域請求包含content-type res.addHeader("Access-Control-Allow-Headers", "Content-Type,X-CAF-Authorization-Token,sessionToken,X-TOKEN"); if (((HttpServletRequest) servletRequest).getMethod().equals("OPTIONS")) { servletResponse.getWriter().println("ok"); return; } filterChain.doFilter(servletRequest, servletResponse); } }
方式四:實現WebMvcConfigurer中addCorsMappings方法
import org.springframework.stereotype.Component; import org.springframework.web.servlet.config.annotation.CorsRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Component public class MyWebMvcConfigurer implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") // 匹配所有的路徑 .allowCredentials(true) // 設置允許憑證 .allowedHeaders("*") // 設置請求頭 .allowedMethods("GET", "POST", "PUT", "DELETE") // 設置允許的方式 .allowedOriginPatterns("*"); } }
方法五:采用nginx做動態代理
到此這篇關於springboot解決跨域的幾種方式的文章就介紹到這瞭,更多相關springboot解決跨域內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- SpringBoot 中實現跨域的5種方式小結
- Spring Boot詳解五種實現跨域的方式
- 關於springboot2.4跨域配置問題
- 解決SpringBoot自定義攔截器和跨域配置沖突的問題
- springboot 設置CorsFilter跨域不生效的解決