在Action中提供了下列几种注解:
ParentPackage
Namespace
Result
Results
注解
描述
Namespace
所期望的命名空间(在“struts.xml”文件中也有定义)的字符串值
ParentPackage
所期望的父package的字符串值
Results
“Result”注解列表
Result
提供了Action结果的映射,它有四个属性:
? name ——action方法的结果名
? type—— 结果类型
? value——任意的结果值。可以是rediect结果类型对应的action名,也可以是dispatcher结果类型对应的JSP
? parameters ——字符串参数组成的数组
Action注解配置
使用方式如下:
@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”。
生命周期回调注解(拦截器注解)
关于方法级的生命周期回调的注解一共有三种,每一种都是在Action处理过程中的特定时刻被调用的。生命周期回调与拦截器及Action代理不同,它们特定于被调用的Action类存在的,并不是那种可以在多个Action中使用的单个的类。
Before:被注解的方法会在Action的逻辑执行前被调用。
BeforeResult:被注解的方法的调用时机是Action的逻辑执行之后,但执行结果还未被调用之前。
After:被注解的方法的调用时机是Action的结果被调用之后,但尚未被返回给用户之前
例如:
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 <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>
分享到:
相关推荐
在"Struts 2使用注解配置Action"中,我们不再需要在struts.xml中为每个Action类手动添加配置。相反,我们可以在Action类或者方法上直接使用注解来声明它们的功能。这样不仅提高了代码的可读性,还使得配置更加灵活。...
首先,了解`@Action`注解是理解Struts2注解配置的关键。这个注解用于标记一个类或方法作为处理HTTP请求的动作。例如: ```java @Action(value = "saveUser", results = { @Result(name = "success", location = ...
Struts2 提供了一种使用注解替代 XML 配置的方式,使得开发者无需编写繁琐的 struts.xml 文件,即可完成Action的配置。 **Struts2 注解配置** 1. **Action 注解** - `@Action` 用于标记一个类或方法作为 Struts2 ...
此外,Struts2还提供了其他注解,如`@Results`、`@Namespace`、`@ParentPackage`等,它们分别用于定义一组结果、Action所属的命名空间以及继承的配置包。这些注解可以帮助我们在不编写XML配置的情况下,完成大部分的...
Struts2 注解配置 Action 及拦截器是 Struts2 框架中的核心组件之一,负责处理用户请求并返回响应结果。下面,我们将通过详细的解释和示例代码,来介绍 Struts2 中的注解配置 Action 及拦截器几种不同方式的写法对应...
使用@Action注解,我们可以直接在Action类上声明其对应的URL路径,而无需在struts.xml文件中进行配置。例如: ```java @Action(value = "saveUser", results = { @Result(name = "success", location = "success....
随着Struts2框架的不断更新和发展,很多开发者在尝试使用注解方式进行配置时往往会遇到不少难题。尤其是在使用Struts2.1及以上版本时,由于大部分教程和资料仍然基于早期版本(如2.0版),这使得学习者难以找到适合...
1. **Action注解**:在Action类上使用`@Action`注解,可以指定Action的基本信息,如命名空间、结果类型等。例如: ```java @Action(value = "login", results = { @Result(name = "success", location = "success....
Struts2中使用注解配置Action方法详解 Struts2框架提供了四个与Action相关的注解类型,分别为ParentPackage、Namespace、Result和Action。这四个注解类型可以帮助开发者更方便地配置Action,实现零配置,零配置将从...
Struts2注解配置教程是指导开发者如何使用Java注解替代传统的XML配置来配置Struts2框架的一个教程系列。本文档主要涵盖了Struts2中注解配置的一些基本知识点以及如何通过注解实现零配置。 ### 注解配置之前 在介绍...
首先,让我们了解Struts2中的Action注解。`@Action`是Struts2提供的主要注解之一,用于标记一个类为Action类。它包含多个属性,如`value`(表示请求URL)、`results`(定义结果映射)等。例如: ```java import ...
Struts2注解登录是Java Web开发中一种简化配置的方式,它允许开发者在代码中直接定义控制器、动作和结果页面的映射,从而避免了传统方式下需要在`struts.xml`配置文件中的繁琐设置。这种做法提高了代码的可读性和可...
- **Action注解**:Action类没有使用正确的注解,例如`@Action`或`@Results`。检查Action类是否正确添加了这些注解,并确保注解的属性值匹配请求URL。 4. **问题排查** - 检查日志:查看服务器日志,通常错误信息...
2. **@Action注解** `@Action` 是Struts2的核心注解,用于标记一个类或者方法为处理HTTP请求的Action。例如: ```java @Action(value = "saveUser", results = { @Result(name = "success", location = "success....
其次,Struts2还提供了其他有用的注解,如`@Namespace`定义Action的命名空间,`@ParentPackage`指定Action继承的包配置,`@Results`用于定义多个结果,以及`@Action(value="", results={...})`的组合使用,可以将...
可以通过配置项 `struts.convention.package.locators` 来指定搜索的位置,例如:`actions`, `action`, `struts`, `struts2` 等。这表示框架会在这些命名空间下查找 Action 类。此外,还可以通过 `struts.convention...
Struts2 是一个流行的Java Web框架,用于构建MVC(模型-视图-控制器)架构的应用程序。在Struts2的版本2.1之后,它引入...例如,可以使用Struts2的注解(如`@Action`,`@Result`等)来覆盖或补充Convention的默认行为。
在处理文件上传和下载这类常见任务时,Struts2提供了一种简洁的方法,尤其是通过注解进行配置,可以实现“零XML”配置,使得开发过程更加高效。本文将深入探讨如何使用Struts2的注解来实现文件的上传与下载。 首先...
通过使用这些注解,Struts2 Convention Plugin可以大大减少XML配置文件的编写工作量,实现快速开发。同时,由于插件遵循一定的约定(比如类名与Action名的关系),使得代码更具有可读性,降低了维护成本。 在实际...
- Struts2支持使用注解在Action类的方法参数上,比如`@RequestParam`,配合`@InitBinder`,可以在控制器层处理编码问题。 4. **JSP页面**: - JSP页面的`;charset=UTF-8" language="java" %>`指令应设置正确的...