随着版本不断的更新,struts2也引进了Annotation的功能,这一改进使得我们的开发效率大大提高,再也不用去配置繁琐的xml,可以更直观明了的在我们处理业务逻辑的方法,或者Action类前面添加Annotation来实现请求映射、拦截、result等功能,其本质和xml区别并不是很大的。
1、配置Annotation之前我们需要添加 struts2-convention-plugin-2.5.12 jar包,如果我们这是maven项目,需要在 pom.xml中添加如下jar包依赖。
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-convention-plugin</artifactId>
<version>2.5.12</version>
</dependency>
2、Struts2使用Annotation开发需要遵循一些规范:
1、Action要必须继承ActionSupport父类
2、Action所在的包名必须以 .action 结尾
3、action中常用的Annotation:
1、 @ParentPackage:对应xml配置文件中的package的父包,一般需要继承struts-default
2、 @Namespace:对应配置文件中的nameSpace,命名空间
3、 @Action,这个Annotation对应<action>节点(写在方法前面)
常用属性属性:
value():表示action的请求名称,对应<action>节点中的name属性
results():表示action的多个result;这个属性是一个数组属性,因此可以定义多个Result
interceptorRefs():表示action的多个拦截器。这个属性也是一个数组属性,因此可以定义多个拦截器;
exceptionMappings():这是异常属性,它是一个ExceptionMapping的数组属性,表示action的异常,在使用时必须引用相应的拦截器
4、@Action中results属性中单个result Annotation的配置:
@Result这个注解对应了<result>节点。这个注解应用于 @Action中results()属性中
常用属性属性:
name():表示action方法的返回值,对应<result>节点的name属性,默认是success
location():表示View层文件的位置(<result>对应于此</result>)
type():是result的类型,对应<result>节点的type属性,默认是dispatcher
例如:(action跳action)
在地址栏输入 login或login.action控制台会打印 login、register。
package com.example.action;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Result;
public class LoginAction {
@Action(
value="login",
results={ @Result(name="login",location="register",type="chain")}
)
public String login(){
System.out.println("login");
return "login";
}
@Action(
value="register",
results={ @Result(name="success",location="/index.jsp")}
)
public String register(){
System.out.println("register");
return "success";
}
}
这个例子还是比较容易理解的,我就不过多的解释啦,需要跳jsp或者其他View层文件的话,只需要把location的属性值改为View层文件的地址即可绝对地址、相对地址都可以
注意:如果使用Annotation来访问我们的action,那么我们的Action类所在的包名,最后一个包的包名必须是以action结尾的。如com.example.action否则struts2会访问不到的,这也是struts2比较蛋疼的地方之一吧。第一次老夫就是被它坑了!