我使用了 Struts 2 框架,并且创建了一个具有登录页面的 Web 应用程序。我有三个不同的
Action
类,分别名为 Action1
、Action2
、Action3
,以及不同的 JSP 页面视图,这些视图是通过在 Action
类中运行一些业务逻辑来呈现的。
现在,我想在
Action
类进行处理之前检查用户是否已登录。
所以,我在下面创建了一个运行良好的拦截器:
public String intercept(ActionInvocation invocation) throws Exception
{
HttpServletRequest request = ServletActionContext.getRequest();
HttpServletResponse response = ServletActionContext.getResponse();
HttpSession session = request.getSession();
if(session.isNew())
{
response.sendRedirect("Login.action");
}
System.out.println("Interceptor Fired");
String result = invocation.invoke();
return result;
}
我想要的
struts.xml
是,而不是为所有操作添加拦截器,如下所示
<interceptor-ref name="newStack"/>
我的
struts.xml
文件有:
<package name="default" extends="struts-default">
<interceptors>
<interceptor name="printMsgInterceptor" class="LoginInterceptor"></interceptor>
<interceptor-stack name="newStack">
<interceptor-ref name="printMsgInterceptor"/>
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
<action name="actone" class="Action1">
<result name="success">/success.jsp</result>
<interceptor-ref name="newStack"/>
</action>
<action name="acttwo" class="Action2">
<result name="success">/success.jsp</result>
<interceptor-ref name="newStack"/>
</action>
<action name="actthree" class="Action3">
<result name="success">/success.jsp</result>
<interceptor-ref name="newStack"/>
</action>
</package>
对于每个动作,我想要一些定义,用
struts.xml
编写,它运行拦截器而不是手动添加
<interceptor-ref name="newStack"/>
<interceptor name="test" class="Full path for LoginInterceptor" />
<interceptor-stack name="testStack">
<interceptor-ref name="test"/>
<interceptor-ref name="defaultStack"/> //here you are including default stack
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="testStack"></default-interceptor-ref>
现在
testStack
将为每个请求执行
使用
<default-interceptor-ref name="newStack"/>
如果您没有为每个操作手动放置
interceptor-ref
,您可以使用default-interceptor-ref
来拦截所有未显式定义拦截器配置的操作。请参阅我们如何配置拦截器以供每个操作使用。
我们可以创建自己的命名堆栈,甚至可以为包声明一个新的默认拦截器堆栈
<package name="default" extends="struts-default" > <interceptors> <interceptor-stack name="myStack"> <interceptor-ref name="timer"/> <interceptor-ref name="logger"/> <interceptor-ref name="defaultStack"/> </interceptor-stack> </interceptors>
但是,如果您说上面的拦截器工作正常,我会鼓励您对业务逻辑保持谨慎,如果第一次执行失败,则登录操作将不会被执行。您应该检查经过身份验证的用户的结果,并将这些结果保存在您可以在拦截器中检查的会话中,而不是检查新会话。 请参阅此问题的示例。
编写使用经过身份验证的用户信息和会话的拦截器的示例,您可以在here找到。