一、拦截器

说明:

    拦截器(Interceptor):拦截器是Struts2的核心,Struts2的众多功能都是通过拦截器来实现的。

    拦截器跟filter的概念是非常类似的,拦截器只能拦截Action,而filter是可以过滤所有的访问。

  所有的Struts 2的拦截器都直接或间接实现接口com.opensymphony.xwork2.interceptor.Interceptor。该接口提供了三个方法:

  1)void init(); 在该拦截器被初始化之后,在该拦截器执行拦截之前,系统回调该方法。对于每个拦截器而言,此方法只执行一次。

  2)void destroy();该方法跟init()方法对应。在拦截器实例被销毁之前,系统将回调该方法。

  3)String intercept(ActionInvocation invocation) throws Exception; 该方法是用户需要实现的拦截动作。该方法会返回一个字符串作为逻辑视图。

  除此之外,继承类com.opensymphony.xwork2.interceptor.AbstractInterceptor是更简单的一种实现拦截器类的方式,因为此类提供了init()和destroy()方法的空实现,这样我们只需要实现intercept方法。(下文便是采用此方法)


代码:

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;

import com.opensymphony.xwork2.ActionInvocation;

import com.opensymphony.xwork2.interceptor.AbstractInterceptor;


public class CityInterceptor extends AbstractInterceptor {

private static final long serialVersionUID = 1L;

//下文目前只有一个用途,判断是否登录;

public String intercept(ActionInvocation actionInvocation) throws Exception {

ActionContext ac = actionInvocation.getInvocationContext();

Map<String, Object> session = ac.getSession();

String cityId = null;

if(session.get("cityId ")!=null){

cityId = (String.valueOf(session.get("cityId ")));

}

if (StringUtil.isNull(loginCityId)) {

return "reLogin";

}

return actionInvocation.invoke();

}

}

二、spring 配置文件:

        

<bean id="cityInterceptor" class="cn.CityInterceptor" scope="prototype"></bean>


三、struts 配置文件:

配置文件中用<interceptors>中进行配置.注意拦截器的init方法也是在服务器一启动的时候就调用的,跟filter一样的.整个struts都是靠这些拦截器所串联起来的.我们并没有在action里面配置也没问题啊,因为他有个默认的拦截器栈嘛.是通过 <default-interceptor-ref name="defaultStack"/>来指定的,下面我们便是在packge里将其覆盖为我们自己定义的拦截器栈,这样该packge中的所有action都会默认调用自定义的拦截器栈了。


<package name="cityInterceptor" extends="struts-default">

<interceptors>

<!-- 定义一个拦截器 --> 

      <interceptor name="cityInterceptor" class="cityInterceptor" />

            <!-- 定义拦截器栈 -->

            <interceptor-stack name="mydefault">

                <!-- 引用拦截器一(默认拦截器) -->

                <interceptor-ref name="defaultStack"/> 

                <!-- 引用拦截器二(自定义拦截器) --> 

                <interceptor-ref name="cityInterceptor" />

            </interceptor-stack>

      </interceptors>

      <!--将自定义的拦截器栈设置为默认调用,这会覆盖系统struts的默认设置--> 

      <default-interceptor-ref name="mydefault"></default-interceptor-ref>

       <!--定义全局Result-->

       <global-results>

       <result name="reLogin" type="redirect">/cityLogin.action</result>

       </global-results>

 </package>


注:为了能够灵活调用,先将拦截器定义在一个空package,需要使用拦截器时直接继承该package; 其效果等同于直接将action写在该package中;同步也可以继承多个package,以逗号隔开就行;   

<package name="manage" extends="cityInterceptor" namespace="/cityManage" >  

    <action name="queryCity" class="queryAction" method="queryCity">

        <result name="success">。。。</result>

    </action>

</package>


当然如果只是个别action需要使用拦截器:

1、第一个pakege "cityInterceptor"中就不必将拦截器栈设置为默认使用;

2、在单个action直接使用<interceptor-ref name="mydefault"/> (可以像使用拦截器一样使用拦截器栈

<action name="queryCity" class="queryAction" method="queryCity">

        <result name="success">。。。</result>

                <interceptor-ref name="mydefault"/>

    </action>


再者如果你不想使得拦截器栈的话,也可以在action中直接调用拦截器;

<action name="queryCity" class="queryAction" method="queryCity">

        <result name="success">。。。</result>

<!-- 使用拦截器,一般配置在result之后, -->

<!-- 引用系统默认的拦截器 -->

<interceptor-ref name="defaultStack"/>

          <interceptor-ref name="拦截器名或拦截器栈名"/>

</action>