前几天做了一个项目,需要在调用action之前进行验证是否未登录用户。写了一个拦截器记录一下:
登录后把用户的信息存入session当中
if (checkUser.getPassword().equals(tqUser.getPassword())) {
HttpSession session = ServletActionContext.getRequest().getSession(true);
session.setAttribute("UserInfo", checkUser);
return SUCCESS;
}
写拦截器LoginInteceptor 继承 AbstractInterceptor 代码如下:
package com.taoqu.inteceptor;
import java.util.Map;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
public class LoginInteceptor extends AbstractInterceptor{
@Override
public String intercept(ActionInvocation invocation) throws Exception {
// TODO Auto-generated method stub
ActionContext ctx = invocation.getInvocationContext();
Map session = ctx.getSession();
Object user = session.get("UserInfo");
if(user != null){
return invocation.invoke();
}
ctx.put("tip", "您还没有登录,请登录或注册先亲。。");
return "login";
}
}
struts.xml文件中修改配置文件中的配置信息,声明一个拦截器,然后再需要拦截的action中标明我们在执行之前要过一下这个拦截器,看看是否用户登录如果登录了才能执行下一步,否则跳转到login
/login. jsp /build.jsp ............... /error.jsp /findcreatins.action
写一个记录一下,大神们可以拍砖。