在Action中提供了下列几种注解:
ParentPackage
Namespace
Result
Results
注解 | 描述 |
Namespace | 所期望的命名空间(在“struts.xml”文件中也有定义)的字符串值 |
ParentPackage | 所期望的父package的字符串值 |
Results | “Result”注解列表 |
Result | 提供了Action结果的映射,它有四个属性: ² name ——action方法的结果名 ² type—— 结果类型 ² value——任意的结果值。可以是rediect结果类型对应的action名,也可以是dispatcher结果类型对应的JSP ² parameters ——字符串参数组成的数组 |
使用方式如下:
@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的名称列表。
<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”。