千家信息网

SpringBoot拦截器返回false显示跨域问题怎么解决

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,本文小编为大家详细介绍"SpringBoot拦截器返回false显示跨域问题怎么解决",内容详细,步骤清晰,细节处理妥当,希望这篇"SpringBoot拦截器返回false显示跨域问题怎么解决"文章能
千家信息网最后更新 2025年01月20日SpringBoot拦截器返回false显示跨域问题怎么解决

本文小编为大家详细介绍"SpringBoot拦截器返回false显示跨域问题怎么解决",内容详细,步骤清晰,细节处理妥当,希望这篇"SpringBoot拦截器返回false显示跨域问题怎么解决"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

项目最近添加了一个ip黑白名单的功能, 发现如果ip过滤的拦截器返回 false 后前端会显示跨域, 尝试修改MVC配置类后发现还是不行, 最后在拦截器加了个判断就可以了

    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {        // ----------- 加上这个就好了 -----------        if (!(handler instanceof HandlerMethod)) {            return true;        }    }

WebMvcConfigurer 配置类

@Configuration@RestControllerAdvicepublic class WebMvcConfig implements WebMvcConfigurer {    @Resource    private IpFilterInterceptor ipFilterInterceptor;    @Override    public void addInterceptors(InterceptorRegistry registry) {        // IP拦截器        registry.addInterceptor(ipFilterInterceptor)                .addPathPatterns("/**")                .order(5);    }    @Override    public void addCorsMappings(CorsRegistry registry) {        registry.addMapping("/**")                .allowCredentials(true)                .allowedOriginPatterns("*")                .allowedMethods("*")                .allowedHeaders("*")                .maxAge(3600);    }}

修改前的 IP拦截器

@Componentpublic class IpFilterInterceptor implements HandlerInterceptor {    /**     * 是否启用     */    private boolean enable;    /**     * 是否为白名单     */    private boolean isWhiteList;    /**     * 过滤器     */    private List filters;    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {        // 停用        if (!enable) {            return true;        }        String ip = Servlets.getRemoteAddr(request);        // 本机不过滤        if (Const.LOCALHOST_IP_V4.equals(ip)) {            return true;        }        // 过滤        boolean contains = false;        for (String filter : filters) {            if (Strings.isBlank(filter)) {                continue;            }            // 检测            contains = Utils.checkIpIn(ip, filter);            if (contains) {                break;            }        }        // 结果        boolean pass;        if (isWhiteList) {            pass = contains;        } else {            pass = !contains;        }        // 返回        if (!pass) {            response.setContentType(StandardContentType.APPLICATION_JSON);            Servlets.transfer(response, HttpWrapper.of(ResultCode.IP_BAN).toJsonString().getBytes());        }        return pass;    }}

修改后的 IP拦截器

@Componentpublic class IpFilterInterceptor implements HandlerInterceptor {    /**     * 是否启用     */    private boolean enable;    /**     * 是否为白名单     */    private boolean isWhiteList;    /**     * 过滤器     */    private List filters;    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {        // 停用        if (!enable) {            return true;        }        // ----------- 加上这个就好了 -----------        if (!(handler instanceof HandlerMethod)) {            return true;        }        String ip = Servlets.getRemoteAddr(request);        // 本机不过滤        if (Const.LOCALHOST_IP_V4.equals(ip)) {            return true;        }        // 过滤        boolean contains = false;        for (String filter : filters) {            if (Strings.isBlank(filter)) {                continue;            }            // 检测            contains = Utils.checkIpIn(ip, filter);            if (contains) {                break;            }        }        // 结果        boolean pass;        if (isWhiteList) {            pass = contains;        } else {            pass = !contains;        }        // 返回        if (!pass) {            response.setContentType(StandardContentType.APPLICATION_JSON);            Servlets.transfer(response, HttpWrapper.of(ResultCode.IP_BAN).toJsonString().getBytes());        }        return pass;    }}

最后, 问题的原因是出在了拦截器身上 需要在 preHandle 中 判断 handler 的类型必须是 HandlerMethod 的话才能通过

读到这里,这篇"SpringBoot拦截器返回false显示跨域问题怎么解决"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。

0