springboot过滤器执行两次的解决及跨域过滤器问题

 更新时间:2023年12月11日 10:35:47   作者:源人生之路  
这篇文章主要介绍了springboot过滤器执行两次的解决及跨域过滤器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

springboot过滤器执行两次的解决及跨域过滤器

在进行springboot整合过滤器的过程中可能会遇到过滤器执行两次的问题

针对这个问题可能出现的一种原因就是因为在请求执行完之后浏览器会再发一次请求.ico的请求

解决的方法就是在执行过滤器方法之前再加一层判断就好了.

HttpServletRequest request = (HttpServletRequest)servletRequest;
if (request.getRequestURL().toString().matches(".+.ico$")) {
     filterChain.doFilter(servletRequest, servletResponse);
 } else {
     // do something yourself
     filterChain.doFilter(servletRequest, servletResponse);
 }

在不使用框架提供的跨域的方案的情况下可以自己注册一个通用的跨域请求过滤器,具体的代码如下

首先先注册一个过滤器

到springboot

@Bean
    public FilterRegistrationBean corsFilter() {
        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
        CorsFilter corsFilter = new CorsFilter();
        filterRegistrationBean.addUrlPatterns("/*");
        filterRegistrationBean.setFilter(corsFilter);
        return filterRegistrationBean;
    }

具体过滤器的代码

如下

public class CorsFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest)servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        if (request.getRequestURL().toString().matches(".+.ico$")) {
            filterChain.doFilter(servletRequest, servletResponse);
        } else {
            String origin = request.getHeader("Origin");
	       // 简单请求跨域,如果是跨域请求在响应头里面添加对应的Origin
	        if (!StringUtils.isEmpty(origin)) {
	            response.addHeader("Access-Control-Allow-Origin", origin);
	        }
	        // 非简单请求跨域
	        response.addHeader("Access-Control-Allow-Headers", "content-type");
	        // 允许跨域请求的方法
	        response.addHeader("Access-Control-Allow-Methods", "*");
	        // 预检命令缓存 1小时
	//        response.addHeader("Access-Control-Max-Age", "3600");
	        // 携带cookie的跨域
	        response.addHeader("Access-Control-Allow-Credentials", "true");
	        // 放行方法
	        filterChain.doFilter(servletRequest, servletResponse);
        }
    }
    @Override
    public void destroy() {
    }
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java的前期绑定和后期绑定使用示例

    java的前期绑定和后期绑定使用示例

    java的前期绑定在程序执行前根据编译时类型绑定,调用开销较小,如C语言只有前期绑定这种方法调用
    2014-02-02
  • struts2拦截器_动力节点Java学院整理

    struts2拦截器_动力节点Java学院整理

    如何使用struts2拦截器,或者自定义拦截器。下面通过实例代码给大家分享struts2拦截器的相关知识,感兴趣的朋友参考下吧
    2017-09-09
  • jpa实现只查询指定的字段

    jpa实现只查询指定的字段

    这篇文章主要介绍了jpa实现只查询指定的字段,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Servlet实现简单的用户登录功能实例代码

    Servlet实现简单的用户登录功能实例代码

    这篇文章主要给大家介绍了关于利用Servlet实现简单的用户登录功能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • spring中的注解@@Transactional失效的场景代码演示

    spring中的注解@@Transactional失效的场景代码演示

    这篇文章主要介绍了spring中的注解@@Transactional失效的场景代码演示,@Transactional注解是Spring框架提供的用于声明事务的注解,作用于类和方法上,需要的朋友可以参考下
    2024-01-01
  • Spring MVC中的拦截器案例演示

    Spring MVC中的拦截器案例演示

    拦截器可以拦截所有的请求,也可以只拦截满足指定的请求, Spring MVC 的拦截器类似于过滤器,用来执行预处理和后处理操作,本文给大家介绍Spring MVC中的拦截器案例演示,感兴趣的朋友跟随小编一起看看吧
    2023-10-10
  • Java设计模式七大原则之依赖倒置原则详解

    Java设计模式七大原则之依赖倒置原则详解

    依赖倒转原则,即:上层模块不应该依赖底层模块,它们都应该依赖于抽象,抽象不应该依赖于细节,细节应该依赖于抽象。本文将详细介绍Java设计模式七大原则之一的依赖倒置原则,需要的可以参考一下
    2022-02-02
  • java this 用法详解及简单实例

    java this 用法详解及简单实例

    这篇文章主要介绍了java this 用法详解及简单实例的相关资料,需要的朋友可以参考下
    2017-03-03
  • Spring Security实现动态路由权限控制方式

    Spring Security实现动态路由权限控制方式

    这篇文章主要介绍了Spring Security实现动态路由权限控制方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • 养成良好java代码编码规范

    养成良好java代码编码规范

    这篇文章主要介绍了如何养成良好java代码编码规范,规范需要平时编码过程中注意,是一个慢慢养成的好习惯,下面小编就带大家来一起详细了解一下吧
    2019-06-06

最新评论