springBoot 配置跨域跨域的三种方式

第一种 config 配置类 来全局所有跨域访问

@Configuration
  public class WebMvcConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")
                .maxAge(3600)
                .allowCredentials(true);
   }
}

第二种 在需要跨域的整个Controller或者单个方法上添加@CrossOrigin注解

@CrossOrigin
public class UserController {
       
 }

或者

@PutMapping("/saveOrUpdate")
@ApiOperation(value = "保存或修改",notes = "保存或修改")
@CrossOrigin
public Result saveOrUpdate(@RequestBody @Valid BizElUser bizElUser){}

第三种 (通过filter)

@Component
@WebFilter(urlPatterns = "/*", filterName = "authFilter") //这里的“/*” 表示的是需要拦截的请求路径
public class PassHttpFilter implements Filter {
     @Override
     public void init(FilterConfig filterConfig) throws ServletException { }
     @Override
     public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
                HttpServletResponse httpResponse = (HttpServletResponse)servletResponse;
                 httpResponse.setHeader("Access-Control-Allow-Headers","Origin, X-Requested-With, Content-Type, Accept");
                httpResponse.setHeader("Access-Control-Allow-Credentials", "true");
                httpResponse.addHeader("Access-Control-Allow-Origin", "http://127.0.0.1:8080");
                filterChain.doFilter(servletRequest, httpResponse);
            }
      @Override
      public void destroy() { }
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值