您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

怎么在Springboot实现拦截器功能

2025/10/25 10:02:38发布11次查看
prehandle: 预先处理,在目标的controller方法执行之前,进行处理
posthandle: 在目标的controller方法执行之后,到达指定页面之前进行处理
aftercompletion: 在页面渲染之后进行处理
方法:
1.springboot通过实现handlerinterceptor接口实现拦截器
2.通过webmvcconfigurer实现一个配置类,再通过@configuration 注解注入到容器
3.指定拦截规则
 以用户登录为案例,若用户没有登录session里面就没有用户的数据,就会转到首页登录页面
在正确登录之后,就将reglister保存到session中,再次访问页面的时候,登录拦截器就可以找到这个reglister对象,就不需要再次拦截到登录界面了.
package com.zwz.springbootweb.interceptor; import org.springframework.context.annotation.bean;import org.springframework.stereotype.component;import org.springframework.stereotype.service;import org.springframework.web.servlet.handlerinterceptor;import org.springframework.web.servlet.modelandview; import javax.servlet.http.httpservletrequest;import javax.servlet.http.httpservletresponse;import javax.servlet.http.httpsession;import javax.websocket.session; public class logininterceptor implements handlerinterceptor { @override public boolean prehandle(httpservletrequest request, httpservletresponse response, object handler) throws exception { httpsession session = request.getsession(); object reglister = session.getattribute("reglister"); if (reglister != null) { return true; } else { request.setattribute("msg", "请先登录!"); request.getrequestdispatcher("/").forward(request,response); return false; } } @override public void posthandle(httpservletrequest request, httpservletresponse response, object handler, modelandview modelandview) throws exception { handlerinterceptor.super.posthandle(request, response, handler, modelandview); } @override public void aftercompletion(httpservletrequest request, httpservletresponse response, object handler, exception ex) throws exception { handlerinterceptor.super.aftercompletion(request, response, handler, ex); }}
之后通过实现webmvcconfigurer接口实现一个配置类,在配置类中注入拦截器,最后再通过 @configuration 注解注入配置.并且指定拦截的路径和需要放行的路径.
注意:拦截器 /** 会拦截一切资源,包括静态资源,需要将静态资源放行
package com.zwz.springbootweb.config; import com.zwz.springbootweb.interceptor.logininterceptor;import org.springframework.context.annotation.bean;import org.springframework.context.annotation.configuration;import org.springframework.web.filter.hiddenhttpmethodfilter;import org.springframework.web.servlet.config.annotation.interceptorregistry;import org.springframework.web.servlet.config.annotation.pathmatchconfigurer;import org.springframework.web.servlet.config.annotation.webmvcconfigurer;import org.springframework.web.util.urlpathhelper; @configurationpublic class webconfig implements webmvcconfigurer{ @override public void addinterceptors(interceptorregistry registry) { registry.addinterceptor(new logininterceptor()).addpathpatterns("/**").excludepathpatterns("/loginjudge","/","/retolo","/static/**"); }}
拦截器的应用场景
1、日志记录:记录请求信息的日志,以便进行信息监控、信息统计、计算pv(page view)等。
2、权限检查:如登录检测,进入处理器检测检测是否登录,如果没有直接返回到登录页面;
3、性能监控:有时候系统在某段时间莫名其妙的慢,可以通过拦截器在进入处理器之前记录开始时间,在处理完后记录结束时间,从而得到该请求的处理时间(如果有反向代理,如apache可以自动记录);
4、通用行为:读取cookie得到用户信息并将用户对象放入请求,从而方便后续流程使用,还有如提取locale、theme信息等,只要是多个处理器都需要的即可使用拦截器实现。
5、opensessioninview:如hibernate,在进入处理器打开session,在完成后关闭session。
拦截器与过滤器的区别
1、拦截器是基于java的反射机制的,而过滤器是基于函数回调。
2、拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
3、拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
4、拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
5、在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
6、拦截器可以获取ioc容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
以上就是怎么在springboot实现拦截器功能的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product