关于过滤器和拦截器的区别,已经spring boot入门(七)中说明。下面举个过滤器的应用场景,比如用户信息页只有再用户登录后才可以进入,没有登录的用户是无法进入的,此时便可以采用过滤器来讲没有登录的用户"过滤"掉。
1.建立filter包,在此包下建立UrlFilter类,此例我们模拟判断用户请求地址是否有误:UrlFilter代码如下:
@WebFilter(filterName = "test", urlPatterns = "/success/*")
public class UrlFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("----------------------->过滤器被创建");
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) servletRequest;
String requestURI = req.getRequestURI();
System.out.println("--------------------->过滤器:请求地址"+requestURI);
if(!requestURI.contains("info")){
servletRequest.getRequestDispatcher("/failed").forward(servletRequest, servletResponse);
}else{
filterChain.doFilter(servletRequest, servletResponse);
}
}
@Override
public void destroy() {
System.out.println("----------------------->过滤器被销毁");
}
}
注意:@WebFilter注解为声明此类为filter,第一个参数为该filter起一个名字,第二个参数为说明要拦截的请求地址。该类实现了Filter接口,里面有三个方法,分别为过滤器创建、过滤方法和过滤器销毁。我们在过滤方法doFilter执行过滤逻辑。同样,在使用注解的方式(即@WebFilter)声明过滤器时,需要再main函数类上添加@ServletComponentScan(basePackages = "此处写明类地址,格式为包名+类名(如com.yxc.*)"),具体代码请见本人博客"spring boot入门(八)"。
2.为使得模拟效果更好,在TestController类中添加了一个接口方法failed,代码如下:
@RequestMapping("/failed")
public Map<String, String> requestFailed(){
Map<String, String> map = new HashMap<>();
map.put("code", "-1");
map.put("msg", "请求错误");
return map;
}
3.其中我们正常访问的接口方法代码如下:
@RequestMapping("/success/info")
public User userInfo(){
User user = new User();
user.setUsername("Yansir");
user.setPassword("");
user.setNickname("cherish");
user.setGender("女");
user.setAge("1");
return user;
}