springboot前后端分离项目配置跨域、拦截器(同时生效)

使用WebMvcConfigurer接口配置拦截器, 跨域请求会失效, 好像是拦截放行后不会带有跨域信息, 导致失败。下面两个配置可以同时生效。

跨域配置:

@Configuration
@EnableWebMvc
public class CorsConfig implements WebMvcConfigurer {

    @Bean
    public FilterRegistrationBean someFilterRegistration1() {
        //新建过滤器注册类
        FilterRegistrationBean registration = new FilterRegistrationBean();
        // 添加我们写好的过滤器
        registration.setFilter( new SessionFilter());
        // 设置过滤器的URL模式
        registration.addUrlPatterns("/*");
        return registration;
    }
}

拦截器配置(使用过滤器Filter接口):

public class SessionFilter implements Filter {

    private Logger logger = LoggerFactory.getLogger(getClass());

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        //TODO z 这个获取不到内部报错, 提交改回
//        SsoUserVo user = JwtUserUtil.getUserInfo(request);
//        if(user != null){
        if(true){
            filterChain.doFilter(servletRequest, servletResponse);
        }else{
            logger.warn("未获取到用户信息, 请重新登录!");
            response.setCharacterEncoding("UTF-8");
            // 给前端返回json
            response.setContentType("application/json; charset=utf-8");
            PrintWriter out = response.getWriter();
            AjaxResultPo po = AjaxResultPo.failed("未获取到用户信息, 请重新登录!");
            out.append(JSON.toJSONString(po));
            // 要想加一些请求处理可以这样跳转个类或者使用异步
//            request.getRequestDispatcher("/filterReturn").forward(request,response);
        }
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值