本文实例讲述了java自定义拦截器及其用法。分享给大家供大家参考。具体如下:
LoginInterceptor.java文件如下:
package com.tq365.util; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import org.apache.struts2.ServletActionContext; import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.AbstractInterceptor; import com.tq365.vo.User; /** * 自定义的拦截器(放行登录操作和已经登录用户的操作) * @author archie2010 * */ public class LoginInterceptor extends AbstractInterceptor{ private static final long serialVersiOnUID= 1406123004582563032L; @Override public String intercept(ActionInvocation invocation) throws Exception { HttpServletRequest request = ServletActionContext.getRequest(); HttpSession session = ServletActionContext.getRequest().getSession(); User user = (User)session.getAttribute("USER"); // 请求的url String path = request.getServletPath(); boolean flag = false; if("/loginuser.jspx".equals(path)){ flag = true; }else{ if(user!=null){ flag = true; } } System.out.println(path); return flag ? invocation.invoke() : "error"; } }
struts.xml文件如下:
希望本文所述对大家的java程序设计有所帮助。