Struts2使用之Action注解的配置
2011-06-27 16:24
791 查看
在Action中提供了下列几种注解:
ParentPackage
Namespace
Result
Results
注解
描述
Namespace
所期望的命名空间(在“struts.xml”文件中也有定义)的字符串值
ParentPackage
所期望的父package的字符串值
Results
“Result”注解列表
Result
提供了Action结果的映射,它有四个属性:
? name ——action方法的结果名
? type—— 结果类型
? value——任意的结果值。可以是rediect结果类型对应的action名,也可以是dispatcher结果类型对应的JSP
? parameters ——字符串参数组成的数组
Action注解配置
使用方式如下:
Java代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
@ParentPackage(value="struts-default")
@Namespace(value="/test")
@Result(name="success",value="/userSuc.jsp")
@Results({
@Result(name="success",value="/userSuc.jsp",type=org.apache.struts2.dispatcher.ServletRedirectResult.class),
@Result(name="input",value="/main.jsp",type=org.apache.struts2.dispatcher.ServletRedirectResult.class)
})
在使用这些注解的时候,还需要进行额外的一些配置。在web.xml的filter配置中,需要指定哪些package是使用了注解的。配置如下所示,其中参数名必须为“actionPackages”,参数的值就是package的名称列表。
Xml代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
<filter>
<filter-name>struts</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
<init-param>
<param-name>actionPackages</param-name>
<param-value>user.actions,other.actions</param-value>
</init-param>
</filter>
被配置过的每一个package和它的子package都会被扫描到,看其中哪些类实现了Action或者类名以“Action”结尾,然后注解就会被加入到运行时配置中去。如果没有使用namespace注解的话,那么命名空间就会由package名来生成。把“actionPackages”配置值中使用的package名称截掉,就得到了命名空间。
也就是说,如果某个被配置好的action的名字是“actions.admin.user.AddAction”,而“actionPackages”的值为“actions”,那么这个action的命名空间就是“/admin/user”。
生命周期回调注解(拦截器注解)
关于方法级的生命周期回调的注解一共有三种,每一种都是在Action处理过程中的特定时刻被调用的。生命周期回调与拦截器及Action代理不同,它们特定于被调用的Action类存在的,并不是那种可以在多个Action中使用的单个的类。
Before:被注解的方法会在Action的逻辑执行前被调用。
BeforeResult:被注解的方法的调用时机是Action的逻辑执行之后,但执行结果还未被调用之前。
After:被注解的方法的调用时机是Action的结果被调用之后,但尚未被返回给用户之前
例如:
Java代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
public class TestAction extends ActionSupport {
@Before
public void doBefore(){
System.out.println("注解配置的方法在action执行之前调用");
}
@After
public void doAfter(){
System.out.println("注解配置的方法在action执行之后调用");
}
@BeforeResult
public void doBeforeResult(){
System.out.println("注解配置的方法在Result返回之前调用");
}
…….
}
Struts.xml
Xml代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
<package name="test" extends="struts-default">
<interceptors>
<interceptor name="annoInteceptor"
class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor">
</interceptor>
.....
</interceptors>
<action name="text" class="action.TestAction">
.....
<interceptor-ref name="annoInteceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</action>
.......
</package>
ParentPackage
Namespace
Result
Results
注解
描述
Namespace
所期望的命名空间(在“struts.xml”文件中也有定义)的字符串值
ParentPackage
所期望的父package的字符串值
Results
“Result”注解列表
Result
提供了Action结果的映射,它有四个属性:
? name ——action方法的结果名
? type—— 结果类型
? value——任意的结果值。可以是rediect结果类型对应的action名,也可以是dispatcher结果类型对应的JSP
? parameters ——字符串参数组成的数组
Action注解配置
使用方式如下:
Java代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
@ParentPackage(value="struts-default")
@Namespace(value="/test")
@Result(name="success",value="/userSuc.jsp")
@Results({
@Result(name="success",value="/userSuc.jsp",type=org.apache.struts2.dispatcher.ServletRedirectResult.class),
@Result(name="input",value="/main.jsp",type=org.apache.struts2.dispatcher.ServletRedirectResult.class)
})
在使用这些注解的时候,还需要进行额外的一些配置。在web.xml的filter配置中,需要指定哪些package是使用了注解的。配置如下所示,其中参数名必须为“actionPackages”,参数的值就是package的名称列表。
Xml代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
<filter>
<filter-name>struts</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
<init-param>
<param-name>actionPackages</param-name>
<param-value>user.actions,other.actions</param-value>
</init-param>
</filter>
被配置过的每一个package和它的子package都会被扫描到,看其中哪些类实现了Action或者类名以“Action”结尾,然后注解就会被加入到运行时配置中去。如果没有使用namespace注解的话,那么命名空间就会由package名来生成。把“actionPackages”配置值中使用的package名称截掉,就得到了命名空间。
也就是说,如果某个被配置好的action的名字是“actions.admin.user.AddAction”,而“actionPackages”的值为“actions”,那么这个action的命名空间就是“/admin/user”。
生命周期回调注解(拦截器注解)
关于方法级的生命周期回调的注解一共有三种,每一种都是在Action处理过程中的特定时刻被调用的。生命周期回调与拦截器及Action代理不同,它们特定于被调用的Action类存在的,并不是那种可以在多个Action中使用的单个的类。
Before:被注解的方法会在Action的逻辑执行前被调用。
BeforeResult:被注解的方法的调用时机是Action的逻辑执行之后,但执行结果还未被调用之前。
After:被注解的方法的调用时机是Action的结果被调用之后,但尚未被返回给用户之前
例如:
Java代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
public class TestAction extends ActionSupport {
@Before
public void doBefore(){
System.out.println("注解配置的方法在action执行之前调用");
}
@After
public void doAfter(){
System.out.println("注解配置的方法在action执行之后调用");
}
@BeforeResult
public void doBeforeResult(){
System.out.println("注解配置的方法在Result返回之前调用");
}
…….
}
Struts.xml
Xml代码
![](https://oscdn.geek-share.com/Uploads/Images/Content/202008/02/f40420f606da5b6b82a3d3de4d43f915.png)
<package name="test" extends="struts-default">
<interceptors>
<interceptor name="annoInteceptor"
class="com.opensymphony.xwork2.interceptor.annotations.AnnotationWorkflowInterceptor">
</interceptor>
.....
</interceptors>
<action name="text" class="action.TestAction">
.....
<interceptor-ref name="annoInteceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</action>
.......
</package>
相关文章推荐
- Struts2的使用注解配置Action(零配置)
- Struts2使用19 -- 注解配置1 -- Action注解配置
- 深入详解Struts2——使用注解配置Action
- struts2中使用注解配置Action
- struts2基础学习收录重点之OGNL动态配置result , 使用注解配置action,实现java国际化
- struts2使用注解配置Action传参方式
- struts2中使用注解配置Action方法详解
- struts2中使用注解配置Action
- struts2使用注解配置Action之间的跳转
- Struts2的使用注解配置Action(零配置)
- Struts2 使用注解配置Action
- struts2基于注解的action配置
- Struts2基于注解的Action配置
- Struts2基于注解配置Action
- Struts2基于注解的Action配置(二)
- Struts2--基于注解方式Action配置
- Struts2基于注解的Action配置
- Struts2中action用注解的方式配置
- Struts2零配置开发(注解Annotation的使用)
- Struts2的Action配置及使用