SpringBoot中如何使用过滤器以及如何处理依赖注入失效

梦想不抛弃苦心追求的人,只要不停止追求,你们会沐浴在梦想的光辉之中。再美好的梦想与目标,再完美的计划和方案,如果不能尽快在行动中落实,最终只能是纸上谈兵,空想一番。只要瞄准了大方向,坚持不懈地做下去,才能够扫除挡在梦想前面的障碍,实现美好的人生蓝图。SpringBoot中如何使用过滤器以及如何处理依赖注入失效,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

一、如何使用过滤器

1、写注册器

package usi.eip.sys.unifiedCertification.config;

import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import usi.eip.sys.unifiedCertification.filter.UnifiedFilter;


/**
* @version 创建时间:2020年7月13日 下午2:34:00
* 类说明
*/
@Configuration
public class FilterConfig {
	@SuppressWarnings({ "rawtypes", "unchecked" })
	@Bean
    public FilterRegistrationBean registFilter() {
        FilterRegistrationBean registration = new FilterRegistrationBean();
        registration.setFilter(new UnifiedFilter());
        registration.addUrlPatterns("/*");
        registration.setName("MyFilter");
        registration.setOrder(0);
        return registration;
    }
}

注意:

  • 务必添加@Configuration注解
  • UrlPatterns就是控制器具体的mapping
  • setName必须与指定过滤器的类名一致
  • setOrder指优先级,数字越小优先级越高

2、编写过滤器,实现filter类

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
 * @version 创建时间:2020年7月13日 下午3:26:03
 * 类说明
 */
public class MyFilter implements Filter{
	private static final Logger log = LoggerFactory.getLogger(UnifiedFilter.class);
	
	@Override
	public void init(FilterConfig filterConfig) throws ServletException {
		log.info("--------------拦截启动---------------");
	}

	@SuppressWarnings("unlikely-arg-type")
	@Override
	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
			throws IOException, ServletException {
		HttpServletRequest req = (HttpServletRequest) request;
		HttpServletResponse res = (HttpServletResponse) response;
		log.info("拦截成功,放行");
		chain.doFilter(req,res);
	}

	@Override
	public void destroy() {
		log.info("--------------拦截销毁--------------");
	}

}

二、依赖注入失效

在过滤器中使用@Autowierd或者@Resource进行依赖注入是行不通的,因为:
Filter比Servlet先加载,用依赖注入是不行的,需要通过WebApplicationContext获取Bean
具体写法如下:

private <T> T getBean(Class<T> clazz, HttpServletRequest request) {
		WebApplicationContext applicationContext = WebApplicationContextUtils
				.getRequiredWebApplicationContext(request.getServletContext());
		return applicationContext.getBean(clazz);
	}

构建私有化方法,利用泛型和MVC的根容器获取实体:
例如

private MyRedisUtil getMyRedisUtil(HttpServletRequest request) {
		return getBean(MyRedisUtil.class, request);
	}

获得指定类以后,可以像普通使用依赖注入的类一样使用这个类

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/153539.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!