Springboot跨域处理的多种方式小结
测试工具 IDEA
什么是跨域
当一台服务器资源从另一台服务器(不同 的域名或者端口)请求一个资源或者接口,就会发起一个跨域 HTTP 请求。
浏览器出于安全考虑,会限制跨域访问,就是不允许跨域请求资源,要求协议,IP和端口必须都相同,其中有一个不同就会产生跨域问题,这就是同源策略。
跨域举例
请求方 | 响应方 | 是否跨域 | 原因 |
---|---|---|---|
http://www.ming.com | http://www.ming.com/test.html | 否 | 协议、域名、端口相同 |
http://www.ming.com | https://www.ming.com/test.html | 是 | 协议不同 |
http://www.ming.com | http://www.minggod.com/test.html | 是 | 主域名不同 |
http://www.ming.com | http://haha.ming.com/test.html | 是 | 主域名相同、子域名不同 |
http://www.ming.com:8080 | http://www.ming.com:8090/test.html | 是 | 端口不同 |
跨域访问实例
后端测试代码
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class CorsController { @GetMapping("/cors") public String hello(){ return "hello cors"; } }
用浏览器打开,我这里配置的端口是8090
在前端项目中用axios访问时
<template> <span>跨域请求:{{result}}</span> </template> <script> import axios from 'axios'; export default { name: "Cors", data(){ return { result:"" } }, methods:{ getTest(){ axios.get("http://localhost:8090/cors").then(res=>{ console.log(res.data) this.result=res.data }) } }, created() { this.getTest(); } } </script> <style scoped> </style>
报错中的关键词
Access-Control-Allow-Origin
跨域处理(后端)
说明:
这里是针对Springboot 2.4.0以后的写法,之前的版本写法是.allowedOrigins(*)
2.4.0之后会报错替换成.allowedOriginPatterns即可
代码中会有注释说明
1.添加跨域配置类
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 GlobalCorsConfig { @Bean public CorsFilter corsFilter() { //1. 添加 CORS配置信息 CorsConfiguration config = new CorsConfiguration(); //放行哪些原始域 config.addAllowedOriginPattern("*");//2.4.0后的写法 // config.addAllowedOrigin("*"); //是否发送 Cookie config.setAllowCredentials(true); //放行哪些请求方式 config.addAllowedMethod("*"); //放行哪些原始请求头部信息 config.addAllowedHeader("*"); //暴露哪些头部信息 config.addExposedHeader("*"); //2. 添加映射路径 UrlBasedCorsConfigurationSource corsConfigurationSource = new UrlBasedCorsConfigurationSource(); corsConfigurationSource.registerCorsConfiguration("/**",config); //3. 返回新的CorsFilter return new CorsFilter(corsConfigurationSource); } }
重启后端服务后,刷新前端页面正常访问,效果如下
2. 重写WebMvcConfigurer
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("/**") //是否发送Cookie .allowCredentials(true) //放行哪些原始域 //.allowedOrigins("*") .allowedOriginPatterns("*")//2.4.0后的写法 .allowedMethods(new String[]{"GET", "POST", "PUT", "DELETE"}) .allowedHeaders("*") .exposedHeaders("*"); } }
3. 注解 @CrossOrigin
类上注解
@RestController @CrossOrigin("*") public class CorsController { @GetMapping("/cors") public String hello(){ return "hello cors"; } }
方法上注解
方法可以单独跨域,没有 @CrossOrigin(“*”) 注解的方法则不行
import org.springframework.web.bind.annotation.CrossOrigin; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class CorsController { @GetMapping("/cors") @CrossOrigin("*") public String hello(){ return "hello cors"; } @GetMapping("/cors1") public String hello1(){ return "hello cors1"; } }
4.自定义过滤器
可以正常跨域
import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Component; @Component public class MyCorsFilter implements Filter { public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { HttpServletResponse response = (HttpServletResponse) res; HttpServletRequest httpServletRequest = (HttpServletRequest) req; response.setHeader("Access-Control-Allow-Origin", httpServletRequest.getHeader("origin")); response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, HEAD"); response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Headers", "access-control-allow-origin, authority, content-type, version-info, X-Requested-With"); response.setHeader("Access-Control-Allow-Credentials", "true"); chain.doFilter(req, res); } public void init(FilterConfig filterConfig) {} public void destroy() {} }
5.手动设置响应头(局部跨域)
此方案听说可以用,但明哥自己测试了,不能用,依然有问题,不建议!
@GetMapping("/cors1") public String hello1(HttpServletResponse response){ response.addHeader("Access-Allow-Control-Origin","*"); return "hello cors1"; }
小结
这节总结了“ Springboot跨域处理 ”,希望能对大家有所帮助。
到此这篇关于Springboot跨域处理的几种方式的文章就介绍到这了,更多相关Springboot跨域处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java Mybatis框架Dao层的实现与映射文件以及核心配置文件详解分析
MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO为数据库中的记录2021-10-10Spring AI 使用本地 Ollama Embeddings的操作方法
使用 OpenAI 的 Embeddings 接口是有费用的,如果想对大量文档进行测试,使用本地部署的 Embeddings 就能省去大量的费用,所以我们尝试使用本地的 Ollama Embeddings,这篇文章主要介绍了Spring AI 使用本地 Ollama Embeddings,需要的朋友可以参考下2024-05-05
最新评论