springmvc登录拦截器
2014-08-08 09:42
344 查看
1、代码部分
package com.fly.handler;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.session.Session;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import com.fly.common.contant.Constants;
import com.fly.model.User;
public class LoginHandlerInterceptor extends HandlerInterceptorAdapter {
/**
* @author:fly
* session无效验证(shiroSession方式)
*
*/
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
String path = request.getServletPath();
if(path.matches(Constants.NO_INTERCEPTOR_PATH)){
return true;
}else{
Session shiroSession = SecurityUtils.getSubject().getSession();
User user = (User) shiroSession.getAttribute(Constants.CURRENT_USER);
if(user==null){
response.sendRedirect(request.getContextPath()+"/login");
return false;
}
return true;
}
}
}
二、配置文件部分
<!-- 拦截器配置 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/*"/>
<bean class="com.fly.handler.LoginHandlerInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
package com.fly.handler;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.session.Session;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
import com.fly.common.contant.Constants;
import com.fly.model.User;
public class LoginHandlerInterceptor extends HandlerInterceptorAdapter {
/**
* @author:fly
* session无效验证(shiroSession方式)
*
*/
@Override
public boolean preHandle(HttpServletRequest request,
HttpServletResponse response, Object handler) throws Exception {
String path = request.getServletPath();
if(path.matches(Constants.NO_INTERCEPTOR_PATH)){
return true;
}else{
Session shiroSession = SecurityUtils.getSubject().getSession();
User user = (User) shiroSession.getAttribute(Constants.CURRENT_USER);
if(user==null){
response.sendRedirect(request.getContextPath()+"/login");
return false;
}
return true;
}
}
}
public static final String NO_INTERCEPTOR_PATH = ".*/((login)|(logout)|(code)).*"; //不对匹配该值的访问路径拦截(正则)
二、配置文件部分
<!-- 拦截器配置 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/*"/>
<bean class="com.fly.handler.LoginHandlerInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
相关文章推荐
- 基于SpringMVC的登录拦截器
- SpringMVC配置拦截器实现登录控制
- SpringMVC登录拦截器
- SpringMVC拦截器实现登录认证
- SpringMVC 拦截器实现原理和登录实现
- springmvc 自定义拦截器实现未登录用户的拦截
- springmvc登录拦截器的实现
- 在springmvc配置拦截器拦截未登录用户操作
- springmvc拦截器,用户登录拦截过程
- SpringMVC拦截器(实现登录验证拦截器)
- springmvc拦截器实现对用户登录状态的判断
- springMVC 拦截器如何做登录检查及页面跳转
- SpringMvc使用拦截器实现登录认证
- SpringMVC拦截器实现单点登录
- SpringMVC拦截器实现登录控制
- springMVC 拦截器如何做登录检查及页面跳转
- SpringMVC拦截器实现登录控制
- SpringMVC拦截器实现登录
- springmvc验证登录用过滤器还是拦截器
- SpringMVC之Interceptor拦截器之登录拦截器