您的位置:首页 > 编程语言 > Java开发

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;
}
}

}


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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: