springMVC中实现用户登录权限验证
通过上网搜资料显示,使用filter和interceptor都可以实现。不过推荐使用interceptor.
下面就使用Interceptor实现用户登录权限验证功能。
拦截器需要实现Inceptor拦截器接口的三个方法。
1.preHandle方法,顾名思义,该方法将在请求处理之前进行调用。SpringMVC 中的Interceptor 是链式的调用的,在一个应用中或者说是在一个请求中可以同时存在多个Interceptor 。每个Interceptor 的调用会依据它的声明顺序依次执行,而且最先执行的都是Interceptor 中的preHandle 方法,所以可以在这个方法中进行一些前置初始化操作或者是对当前请求的一个预处理,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。该方法的返回值是布尔值Boolean类型的,当它返回为false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方法,如果已经是最后一个Interceptor 的时候就会是调用当前请求的Controller 方法。
2.postHandle方法,由preHandle 方法的解释我们知道这个方法包括后面要说到的afterCompletion 方法都只能是在当前所属的Interceptor 的preHandle 方法的返回值为true 时才能被调用。postHandle 方法,顾名思义就是在当前请求进行处理之后,也就是Controller 方法调用之后执行,但是它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作。postHandle 方法被调用的方向跟preHandle 是相反的,也就是说先声明的Interceptor 的postHandle 方法反而会后执行。
3.afterCompletion方法,该方法也是需要当前对应的Interceptor 的preHandle 方法的返回值为true 时才会执行。顾名思义,该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。这个方法的主要作用是用于进行资源清理工作的。
下面实现自己的拦截器
package com.huitong.util; 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; public class StudentAuth implements HandlerInterceptor { public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); Object stu = session.getAttribute("student"); if( stu == null ){ response.sendRedirect("/webapp1/index.jsp"); return false; } return true; } public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }
最后需要在spring-mvc.xml配置文件中进行拦截器配置,下面是配置片段
<mvc:interceptors> <mvc:interceptor> <!-- 先匹配所有路径,然后排除不需要检查的路径 --> <mvc:mapping path="/**"/> <!-- 与登录相关的请求 --> <mvc:exclude-mapping path="/*.jsp"/> <mvc:exclude-mapping path="/student/login.action"/> <mvc:exclude-mapping path="/student/register.action"/> <!-- 以下是静态资源 --> <mvc:exclude-mapping path="/images/**" /> <mvc:exclude-mapping path="/css/**" /> <mvc:exclude-mapping path="/font/**" /> <mvc:exclude-mapping path="/js/**" /> <mvc:exclude-mapping path="/datepicker/**" /> <!-- 用户是否已经登录的检查bean --> <bean class="com.huitong.util.StudentAuth"/> </mvc:interceptor> </mvc:interceptors>
最后可以测试使用了
如果觉得有用,想赞助一下请移步赞助页面:赞助一下