另一个 spring 拦截器

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

import com.test.entity.Employee;

/**
* Spring 拦截器
*
* @author jhwen
*
*/
public class SessionInterceptor extends HandlerInterceptorAdapter {

private final Logger logger = Logger.getLogger(SessionInterceptor.class);

/**
* 在业务处理器处理请求之前被调用
*/
public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
Object handler) throws Exception{

//要排除拦截的请求
String[] ignoreRegexs = new String[]{"login.do","checkCode.do"};

//获取客户端请求URI
String requestURI = request.getRequestURI();

//获取客户端请求
if(null!=requestURI && !"".equals(requestURI)){
//不同的工程,substring(int paramInt1,int paramInt2)的paramInt1不同
requestURI = requestURI.substring(8, requestURI.length());
}

for(int i=0; i<ignoreRegexs.length; i++){

String ignoreRegex = ignoreRegexs[i];

/**
* 如果是login.do 和 checkCode.do, 则不做拦截
*/
if(ignoreRegex.equals(requestURI)){
return true;
}
}

/**
* 如果不是login.do(登录) 和 checkCode.do(检验验证码), 则做拦截,
* 并且,判断是否已经登录
*/
Employee emp = (Employee)request.getSession().getAttribute("emp");

/**
* 如果未登录,则不允许操作;
* 如果已经登录,则允许做其他的操作.
*/
if(null == emp){
return false;
}else{
return true;
}
}

}

Spring 的核心配置文件 applicationContext.xml:

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
<property name="interceptors">
<list>
<bean class="com.test.common.core.interceptor.SessionInterceptor" />
</list>
</property>
</bean>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值