需要实现的功能:判断用户是否已登录,未登录用户禁止访问任何页面或action,自动跳转到登录页面。
过程:因为对过滤器和拦截器都不熟悉,开始两种方式都问题不断,后调试通过,贴在这里留作小结和备忘
过滤器filter实现
配置:web.xml
- <filter>
- <filter-name>RightFilter</filter-name>
- <filter-class>com.***.rights.RightFilter</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>RightFilter</filter-name>
- <url-pattern>*.jsp</url-pattern>
- </filter-mapping>
- <filter-mapping>
- <filter-name>RightFilter</filter-name>
- <url-pattern>*.action</url-pattern>
- </filter-mapping>
代码:
- mport java.io.IOException;
-
- import javax.servlet.Filter;
- import javax.servlet.FilterChain;
- import javax.servlet.FilterConfig;
- import javax.servlet.ServletException;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import javax.servlet.http.HttpSession;
-
- public class RightFilter extends HttpServlet implements Filter {
-
- public void doFilter(ServletRequest arg0, ServletResponse arg1,
- FilterChain arg2) throws IOException, ServletException {
- HttpServletResponse response = (HttpServletResponse) arg1;
- HttpServletRequest request=(HttpServletRequest)arg0;
- HttpSession session = request.getSession(true);
- String usercode = (String) session.getAttribute("usercode");
- String url=request.getRequestURI();
- if(usercode==null || usercode.equals(""))
- {
-
- if(url!=null && !url.equals("") && ( url.indexOf("Login")<0 && url.indexOf("login")<0 ))
- {
- response.sendRedirect("登录路径");
- return ;
- }
- }
-
- arg2.doFilter(arg0, arg1);
- return;
- }
-
- public void init(FilterConfig arg0) throws ServletException {
-
-
- }
配置中的filter-mapping,定义的是需过滤的请求类型,上面的配置即过滤所有对jsp页面和action的请求。过滤器的实现与struts2、spring框架无关,在用户请求被相应前执行,在过滤器中,可使用response.sendRedirect("")等方法
跳转到需要的链接,如登录页面、错误页面等,不需要跳转时,arg2.doFilter(arg0, arg1);即可继续执行用户的请求。注意使用filter时避免连续两次跳转,否则会报java.lang.IllegalStateException错误,具体配置方法网上有,除非必要,不建议使用/*(过滤所有访问)的配置方式,这样配置,图片、js文件、css文件等访问都会被过滤
拦截器interceptor实现:
配置:struts.xml
- <interceptors>
-
- <interceptor class="com.***.rights.RightInterceptor" name="rightInterceptor"/>
-
- <interceptor-stack name="mydefault">
-
- <interceptor-ref name="defaultStack"/>
-
- <interceptor-ref name="rightInterceptor"/>
- </interceptor-stack>
- </interceptors>
- <default-interceptor-ref name="mydefault" />
-
- <global-results>
- <result name="login">Login.jsp</result>
- <result name="error">/error.jsp </result>
- </global-results>
代码:
- import java.util.HashMap;
- import java.util.Map;
- import com.opensymphony.xwork2.Action;
- import com.opensymphony.xwork2.ActionInvocation;
- import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
- import com.opensymphony.xwork2.ActionContext;
- public class RightInterceptor extends AbstractInterceptor {
-
- @Override
- public String intercept(ActionInvocation invocation) throws Exception {
-
- try
- {
- ActionContext actionContext = ActionContext.getContext();
- Map<String,Object> session = actionContext.getSession();
- String user=session.get("usercode").toString();
-
- if((user==null || user.equals("")) && !invocation.getAction().getClass().getName().equals("登录action"))
- {
- return Action.LOGIN;
- }
- }
- catch(Exception e)
- {
- e.printStackTrace();
- return Action.LOGIN;
- }
-
- return invocation.invoke();
-
-
- }
-
- }
拦截器由spring管理,只对action起作用,不能拦截jsp页面、图片等其他资源。拦截器截获用户对action的访问,如需要跳转,只需如action一样返回一个result,spring根据result的配置执行跳转。如无需跳转,可调用invocation.invoke();方法来执行用户请求的action。拦截器在action之前开始,在action完成后结束(如被拦截,action根本不执行)
如不进行处理,过滤器和拦截器都会将正常的登录操作屏蔽,因此过滤器中需要判断用户访问的url是否为登录操作或登录页面,拦截器中需要判断用户访问的action是否登录action。(暂未考虑其他区分方法,留问。)
具体配置不加说明,网上很多
|