SpringBoot 配置跨域

SpringBoot 配置跨域

博客部分参考文章:https://www.cnblogs.com/diandianquanquan/p/10607102.html

1、什么是跨域

跨域指浏览器不允许当前页面的所在的源去请求另一个源的数据。源指协议,端口,域名。只要这个3个中有一个不同就是跨域。

最近在学习使用Vue开发项目,由于是前后端分离的模式,前后端拥有不同的域名及端口,因此需要配置跨域。

2、Cors协议

H5中的新特性:Cross-Origin Resource Sharing(跨域资源共享),可以为我们解决跨域问题。

关于 Cors协议参考文章:http://www.ruanyifeng.com/blog/2016/04/cors.html

3、SpringBoot配置跨域

SpringBoot配置跨域有三种方式:

3.1、@CrossOrigin

@RestController
@RequestMapping("/lin/user")
@CrossOrigin
public class UserController {

    @Autowired
    private IUserService userService;

该方式比较直接,但也比较繁琐,需要在每个Controller都配置注解才可以。

3.2 配置 filter

@Component
public class CorsConfiguration implements Filter {

    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", "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");
        chain.doFilter(req, res);
    }
    public void init(FilterConfig filterConfig) {}
    public void destroy() {}
}

该代码参考其他博主。

3.3 实现 WebMvcConfigurer

@Configuration
public class CorsConfiguration implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowCredentials(true)
                .allowedMethods("GET", "POST", "DELETE", "PUT")
                .maxAge(3600);
    }
}
posted @ 2020-09-03 14:48  MyDistance  阅读(808)  评论(0编辑  收藏  举报