博客
关于我
【springboot】拦截器和过滤器的实现
阅读量:330 次
发布时间:2019-03-04

本文共 3722 字,大约阅读时间需要 12 分钟。

拦截器与过滤器在Spring Boot应用中的实现与配置

在Spring Boot项目中,拦截器和过滤器是非常重要的技术工具,能够帮助我们对应用程序的请求进行统一管理和权限控制。本文将详细介绍如何实现和配置拦截器以及过滤器。

第一部分:拦截器的实现

拦截器在Spring Boot中通过实现HandlerInterceptor接口来实现。我们可以创建一个类,继承HandlerInterceptor,并在preHandle方法中实现自己的逻辑。以下是一个典型的拦截器实现:

import java.io.IOException;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import com.example.User;public class AdminInterceptor implements HandlerInterceptor {    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {        User user = (User) request.getSession().getAttribute("USER");        if (user != null) {            return true;        }        response.sendRedirect(request.getContextPath() + "login");        return false;    }    // 其他方法可以留空或根据需求定制}

第二部分:拦截器的配置

在Spring Boot中配置拦截器,需要创建一个配置类,继承WebMvcConfigurer,并在addInterceptors方法中注册拦截器。以下是一个典型的配置类:

import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.InterceptorRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configurationpublic class LoginConfig implements WebMvcConfigurer {    @Override    public void addInterceptors(InterceptorRegistry registry) {        InterceptorRegistration registration = registry.addInterceptor(new AdminInterceptor());        registration.addPathPatterns("/**");        registration.excludePathPatterns("login", "*.html", "*.js", "*.css", "*.woff", "*.ttf");    }}

第三部分:过滤器的实现

过滤器在Spring Boot中通过实现Filter接口来实现。我们可以创建一个类,继承Filter,并在doFilter方法中实现自己的逻辑。以下是一个典型的过滤器实现:

import java.io.IOException;import java.util.Arrays;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 org.springframework.stereotype.Component;@Component@WebFilter(urlPatterns="/**", filterName="loginFilter")public class LoginFilter implements Filter {    private static final String[] excludePathPatterns = { "/stuInfo/getAllStuInfoA" };    @Override    public void init(FilterConfig filterConfig) throws ServletException {        // 初始化逻辑可以在这里添加    }    @Override    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {        String url = request.getRequestURI();        if (Arrays.asList(excludePathPatterns).contains(url)) {            chain.doFilter(request, response);            return;        }        System.out.println("开始拦截了................");        // 业务逻辑可以在这里添加        chain.doFilter(request, response);    }    @Override    public void destroy() {        // 销毁逻辑可以在这里添加    }}

第四部分:过滤器的配置

在Spring Boot中配置过滤器,需要创建一个配置类,注入Filter类到FilterRegistrationBean中,指定URL模式。以下是一个典型的配置类:

import org.springframework.context.annotation.Configuration;import org.springframework.web.filter.FilterRegistrationBean;import org.springframework.web.servlet.config.annotation.EnableWebMvc;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configuration@EnableWebMvcpublic class FilterConfig implements WebMvcConfigurer {    @Bean    public FilterRegistrationBean registFilter() {        FilterRegistrationBean registration = new FilterRegistrationBean();        registration.setFilter(new LoginFilter());        registration.addUrlPatterns("/*");        registration.setName("loginFilter");        registration.setOrder(1);        return registration;    }}

通过以上配置,我们可以在Spring Boot项目中完成拦截器和过滤器的实现和配置。这些技术可以帮助我们对应用程序的请求进行统一管理和权限控制,提升应用的安全性和效率。

转载地址:http://qoih.baihongyu.com/

你可能感兴趣的文章
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>