本文主要讲的是注解方式的拦截器的使用,所以xml文件的不会细讲,文中的代码也比较简单,没有什么权限控制啊,拦截信息之类的代码,重点还是说明注解方式的使用方法,了解了使用方法之后,内容可以自行扩展,这个根据自己的需要来,好了,就这样。
上次写了@Action和@Result两种注解的使用方式,这次要讲的是@Interceptor和@ParentPackage
@InterceptorRef可以就是用来配置拦截器的,有如下属性
虽然是使用注解的方式,但是,还是需要在xml文件中预先配置好拦截器的信息
<interceptor name="interceptor1" class="struts2.interceptor.TestInterceptor1"></interceptor> <interceptor-stack name="interceptorStack1"> <interceptor-ref name="defaultStack"/> <interceptor-ref name="interceptor1"/> </interceptor-stack>
具体的拦截器类如下
public class TestInterceptor1 extends AbstractInterceptor { @Override public String intercept(ActionInvocation arg0) throws Exception { System.out.println("--------TestInterceptor1--------"); return arg0.invoke(); } }
<action name="login" class="struts.action.xxx"> <!-- .... --> <interceptor-ref name="interceptorStack1"/> </action>既然Action都是用注解配置的,那么这时的拦截器就不需要写在这了,具体配置有两种方式,一种是配置在类上的,另外一种是配置在方法上的,下面是配置在方法上的(action例子还是上次文章的例子,具体->别点我,别点我!!不要啊~~)
@Namespace("/") @ParentPackage("default") public class TestAction1 extends ActionSupport { @Action(value = "add", results = { @Result(name = "add", location = "/add.jsp")}, interceptorRefs={ @InterceptorRef("interceptorStack1") }) public String add() throws Exception { return "add"; } }
interceptorRefs可以放多个@InterceptorRef,和results类似
当访问/add的时候,控制台会打印出 ---> --------TestInterceptor1--------
接下来是在类上使用注解
@Namespace("/") @ParentPackage("default") @InterceptorRefs({ @InterceptorRef("interceptorStack1") }) public class TestAction1 extends ActionSupport { @Action(value = "add", results = { @Result(name = "add", location = "/add.jsp")} ) public String add() throws Exception { return "add"; } }这样的效果和上面的是一样的,访问响应的action会打出 ---> --------TestInterceptor1--------
好了,这就是两种使用的方式,从上面的例子看来,好像没有什么区别,其实,区别还是有的,接下来先看下面的action
@Namespace("/") @ParentPackage("default") @InterceptorRef("interceptorStack1") public class TestAction1 extends ActionSupport { @Action(value = "add", results = { @Result(name = "add", location = "/add.jsp") }) public String add() throws Exception { return "add"; } @Action(value = "delete", results = { @Result(name = "delete", location = "/delete.jsp") }) public String delete() throws Exception { return "delete"; } }这样当访问/delete和/add时都会打印出 ---> --------TestInterceptor1--------
再看下下面混合使用两种方式
@Namespace("/") @ParentPackage("default") @InterceptorRef("interceptorStack1") public class TestAction1 extends ActionSupport { @Action(value = "add", results = { @Result(name = "add", location = "/add.jsp")}, interceptorRefs = { @InterceptorRef("interceptorStack2") <span style="white-space:pre"> </span>} ) public String add() throws Exception { return "add"; } @Action(value = "delete", results = { @Result(name = "delete", location = "/delete.jsp") }) public String delete() throws Exception { return "delete"; } }
当访问/delete时会打印出 ---> --------TestInterceptor1--------
这是当然的,delete方法并没有什么改变,和上面作用在类上的拦截器的例子一样,拦截器1会拦截器该方法
而访问/add的时候会发生什么?这时会打印出
---> --------TestInterceptor1-------- 和
---> --------TestInterceptor2--------
(拦截器2和1的定义和1一样,只是将1改成2)
这就是作用在方法上的拦截器和定义在类上的区别
定义在方法上的拦截器会只拦截这个方法,而定义在类上的拦截器会拦截所有的方法
struts2注解总结----@InterceptorRef
原文地址:http://blog.csdn.net/u013160932/article/details/44513487