SpringMVC登录拦截
springmvc的登录拦截很简单,只需要你写一个拦截器类实现HandlerInterceptor这个接口的方法,再在springmvc配置文件中注入即可
- LoginInterceptor
package com.yxx.interceptor;
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 LoginInterceptor implements HandlerInterceptor {
//返回true就是放行,false就直接拦截了
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
//如果session中有登录信息,则放行,登录页放行
if(session.getAttribute("user") != null) return true;
//登录页放行
if(request.getRequestURI().contains("tologin")) return true;
//跳转到登录页
request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request,response);
return false;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
- springmvc中配置
<!-- 配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 拦截所有mvc控制器 -->
<mvc:mapping path="/**"/>
<!-- mvc:exclude-mapping是另外一种拦截,它可以在你后来的测试中对某个页面进行不拦截,这样就不用在
LoginInterceptor的preHandler方法里面获取不拦截的请求uri地址了(优选) -->
<mvc:exclude-mapping path="/login" />
<bean class="com.yxx.interceptor.LoginInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>