ref: http://www.2cto.com/kf/201110/106826.html
使用注解来配置Action的最大好处就是可以实现零配置
先来看看struts.xml中的action都能配置些什么?直接看struts2的dtd中描述Action的部分,示例代码如下:
<!ELEMENT action (param|result|interceptor-ref|exception-mapping)*>
<!ATTLIST action
name CDATA #REQUIRED
class CDATA #IMPLIED
method CDATA #IMPLIED
converter CDATA #IMPLIED
>
零配置就是要替代这些东西,通过约定或者是注解,把这些东西从struts.xml中移除,达到不需要配置就可以指定这些信息并正确运行应用的目的。
@ParentPackage("s2")
@Namespace("/s2")
@Action("/anno")
@Results(
@Result(name="success",location="/anno/success.jsp")
)
@ExceptionMappings(
@ExceptionMapping(exception="java.lang.Exception",result="error")
)
@InterceptorRefs({
@InterceptorRef("logger"),@InterceptorRef("myStack")
})
public class AnnoAction extends ActionSupport{
…
}
要使用注解方式,我们必须添加一个额外包:struts2-convention-plugin-2.x.x.jar
在以上所述的jar文件中定义了一系列的注解,其中比较主要的是:
@ParentPackage,这个注解对应了xml文件中的package节点,它只有一个属性叫value,其实就是package的name属性;
@Namespace,命名空间,也就是xml文件中<package>的namespace属性;
@Action,这个注解对应<action>节点。这个注解可以应用于action类上,也可以应用于方法上。这个注解中有几个属性:
value(),表示action的URL,也就是<action>节点中的name属性;
results(),表示action的多个result;这个属性是一个数组属性,因此可以定义多个Result;
interceptorRefs(),表示action的多个拦截器。这个属性也是一个数组属性,因此可以定义多个拦截器;
params(),这是一个String类型的数组,它按照name/value的形式组织,是传给action的参数;
exceptionMappings(),这是异常属性,它是一个ExceptionMapping的数组属性,表示action的异常,在使用时必须引用相应的拦截器;
@Result,这个注解对应了<result>节点。这个注解只能应用于action类上。这个注解中也有几个属性:
name(),表示action方法的返回值,也就是<result>节点的name属性,默认情况下是【success】;
location(),表示view层文件的位置,可以是相对路径,也可以是绝对路径;
type(),是action的类型,比如redirect;
params(),是一个String数组。也是以name/value形式传送给result的参数;
实际上,struts2中的主要注解就是这些,当然了,还有上面提到的@interceptorRef和@exceptionMapping;基本上,掌握了这些注解就可以了。
但是如果想让这些注解真正工作,必须在配置文件增加几个常量的定义:
struts.convention.default.parent.package:这个常量表示缺省的包名是什么,因为在实际应用中,我们常常定义一个缺省的包,这个包中定义了一大堆的拦截器等等,然后其他的包继承自这个包。这个常量可以配也可以不配;
struts.convention.package.locators:这个常量表示你的action类的java包的包名的后缀是啥:比如action。这个常量也可以不配;
struts.convention.package.locators.basePackage:这个常量表示你的action类的java包package的名字是啥;这个常量也可以不配;
以上三个常量都是辅助作用的,为了让注解真正的工作,必须在配置文件中增加<package>节点的配置,至少是<package name="myPackage" extends="struts-default" />,这样注解就可以使用了。
虽说是零配置的,但struts.xml还是少不了的,配置如下:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.1.7//EN"
"http://struts.apache.org/dtds/struts-2.1.7.dtd">
<struts>
<!-- 请求参数的编码方式-->
<constant name="struts.i18n.encoding" value="UTF-8"/>
<!-- 指定被struts2处理的请求后缀类型。多个用逗号隔开-->
<constant name="struts.action.extension" value="action,do,htm"/>
<!-- 当struts.xml改动后,是否重新加载。默认值为false(生产环境下使用),开发阶段最好打开 -->
<constant name="struts.configuration.xml.reload" value="true"/>
<!-- 是否使用struts的开发模式。开发模式会有更多的调试信息。默认值为false(生产环境下使用),开发阶段最好打开 -->
<constant name="struts.devMode" value="false"/>
<!-- 设置浏览器是否缓存静态内容。默认值为true(生产环境下使用),开发阶段最好关闭 -->
<constant name="struts.serve.static.browserCache" value="false" />
<!-- 指定由spring负责action对象的创建
<constant name="struts.objectFactory" value="spring" />
-->
<!-- 是否开启动态方法调用-->
<constant name="struts.enable.DynamicMethodInvocation" value="false"/>
</struts>
action类的注解:
package com.tjcyjd.web.action;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.ExceptionMapping;
import org.apache.struts2.convention.annotation.ExceptionMappings;
import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.ParentPackage;
import org.apache.struts2.convention.annotation.Result;
import org.apache.struts2.convention.annotation.Results;
import com.opensymphony.xwork2.ActionSupport;
/**
* Struts2基于注解的Action配置
*/
@ParentPackage("struts-default")
@Namespace("/annotation_test")
@Results( { @Result(name = "success", location = "/main.jsp"),
@Result(name = "error", location = "/error.jsp") })
@ExceptionMappings( { @ExceptionMapping(exception = "java.lange.RuntimeException", result = "error") })
public class LoginAction extends ActionSupport {
private static final long serialVersionUID = 2730268055700929183L;
private String loginName;
private String password;
@Action("login") //或者写成 @Action(value = "login")
public String login() throws Exception {
if ("yjd".equals(loginName) && "yjd".equals(password)) {
return SUCCESS;
} else {
return ERROR;
}
}
@Action(value = "add", results = { @Result(name = "success", location = "/index.jsp") })
public String add() throws Exception {
return SUCCESS;
}
public String getLoginName() {
return loginName;
}
public void setLoginName(String loginName) {
this.loginName = loginName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password= password;
}
}
这样就完成了一个基于注解的action配置。
总结常用的注解如下:
Namespace:指定命名空间。
ParentPackage:指定父包。
Result:提供了Action结果的映射。(一个结果的映射)
Results:“Result”注解列表
ResultPath:指定结果页面的基路径。
Action:指定Action的访问URL。
Actions:“Action”注解列表。
ExceptionMapping:指定异常映射。(映射一个声明异常)
ExceptionMappings:一级声明异常的数组。
InterceptorRef:拦截器引用。
InterceptorRefs:拦截器引用组。
另:
每个包都可以设置 package-info.java ,用于写这个包的注释和注解
/**
* Action包
*/
@ParentPackage("ssh-default")
package cn.javass.ssh.doc.action;
import org.apache.struts2.convention.annotation.ParentPackage;
可以在 package-info.java 上添加注解,让这个包内的所有 Action 共享
@ParentPackage("ssh-default")
@Namespace("/doc")
@DefaultInterceptorRef("checkStack")
package cn.javass.ssh.doc.action;
import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.ParentPackage;
import org.apache.struts2.convention.annotation.DefaultInterceptorRef;
可以给 <result><interceptor-ref> 等加上 <param>
@Result(type="json",name="jsonr",params={"root"," citys"}
其中的 params 是键值对,相当于
<result type="json" name=“jsonr">
<param name="root">citys</param>
</result>
可以在struts.xml或struts.properties里设置常量来设置Struts2框架读取哪些类为Action。
1、struts.convention.action.packages:可以使用的Action的祖包,默认为没有, 设置为 cn.javass.ssh 就可以读取这个包及其子包的所有头上注册了【 @Action 】 的类。
2、 struts.convention.package.locators:可以使用的Action的上级包,默认为【action,actions,struts,struts2】,这样就可以读取所有在包中的所有头上注册了【@Action】的类;注意设置的action应为这个包的最后一级包,如cn.javass.ssh.user.action.UserAction。
3、 struts.convention.action.suffix:Action类类名的后缀,默认为Action。
ref: http://zhaozhi3758.iteye.com/blog/894757
action 类名上加注解
@Namespace("/ssi")
@ParentPackage("json-default")
@Action(value = "admin", results = {
@Result(name = "success", location = "/WEB-INF/pages/admin.jsp"),
@Result(name = "json", type = "json", params = { "excludeProperties","adminMgr" }) })
public class AdminAction extends BaseAction{}
多个Action
@Namespace("/msa")
@Result(name = "json", type = "json", params = { "excludeProperties",
".*Manager,.*\\.authorities,.*\\.roles,.*\\.fileCon" })
@Actions(value = {
@Action(value = "foreignship", results = { @Result(name = "success", location = "foreignship/foreignship.jsp") }),
@Action(value = "foreignshipsee", results = { @Result(name = "success", location = "foreignship/foreignshipsee.jsp") }) })
public class TMsaForeignShipArchivesAction extends BaseAction{}
在类方法上加注解
@Action(value = "save")
public String save() {
try{
adminMgr.insert("insertYz_admin", admin);
}catch(Exception e){
msg = e.toString();
success = false;
}
return this.SUCCESS;
}
相关推荐
在"Struts 2使用注解配置Action"中,我们不再需要在struts.xml中为每个Action类手动添加配置。相反,我们可以在Action类或者方法上直接使用注解来声明它们的功能。这样不仅提高了代码的可读性,还使得配置更加灵活。...
通常,这样的文章可能会详细解释如何在实际项目中实现Struts 2的零配置,包括如何使用注解进行配置,如何配置Struts 2的拦截器,以及如何处理Action和结果页面的映射等。 标签 "源码" 暗示讨论可能涉及到对Struts 2...
10. **注解(Annotations)**:从Struts2.1版本开始,框架支持注解配置,允许开发者在Action类和方法上使用注解替代XML配置。 以上只是Struts2框架中的一部分核心概念和特性,实际使用时还需要结合其他技术,如...
在本项目"spring_struts2_mybatis_注解的小实例"中,我们将深入探讨如何使用SSM(Spring、Struts2、MyBatis)框架来实现一个基础的增删改查(CRUD)功能。SSM是Java Web开发中常用的三大组件,它们各自负责不同的...
`struts2_helloworld`标签可能指的是一个简单的入门示例,它通常包括创建一个Action类、一个JSP页面和相关的Struts配置,以展示Struts2的基本工作流程。 总结来说,"Struts2_jquery_json1.0.zip"是一个综合实例,...
在"Struts2_JSON_Demo"这个项目中,我们将看到如何在Struts2框架中集成JSON支持,以实现前后端的数据交互。以下是一些关键的知识点: 1. **Struts2 JSON插件**:Struts2提供了内置的JSON插件,允许我们直接将Action...
5. **Struts2配置**:Struts2的配置可以是XML(struts.xml)或基于注解的,用于定义Action、结果、拦截器栈等。文档中将详细解释如何配置这些元素以满足不同需求。 6. **OGNL(Object-Graph Navigation Language)*...
除了使用XML配置文件,Struts2还支持使用注解进行Action方法的配置。例如,可以使用`@Action`注解来指定Action方法及其返回值: ```java @Action(value = "saveUser", results = { @Result(name = "success", ...
在本压缩包"Struts2_0300_Action"中,包含的是关于Struts2 Action的实践代码,这对于初学者了解和掌握Struts2框架的核心概念和工作原理非常有帮助。 首先,Action是Struts2的核心组件之一,它是业务逻辑的执行者。...
"spring_struts2_mybatis配置文件架包"提供了整合这三个框架所需的配置文件和依赖库,为开发者提供了一个快速入门的模板。这个包对于初学者来说极其有价值,因为它减少了配置工作,使他们能够更快地理解和实践这些...
- **配置Struts2**:配置struts2.xml,定义Action,指定Controller,同时配置结果视图。 - **配置MyBatis**:配置mybatis-config.xml,加载Mapper接口和SQL映射文件。 - **整合Spring和Struts2**:使用Spring的...
1. **XML配置**: 在Struts2的配置文件(struts.xml或struts.properties)中,我们需要为每个Action类指定一个唯一的namespace和actionName。例如: ```xml <package name="default" namespace="/" extends="struts...
在这个"struts2.3.4.1注解零配置"的例子中,我们将深入探讨如何利用Struts2的注解来构建一个简单的登录系统。 首先,了解Struts2的核心概念是必要的。Struts2是一个基于MVC(Model-View-Controller)设计模式的框架...
Struts2 提供了一种使用注解替代 XML 配置的方式,使得开发者无需编写繁琐的 struts.xml 文件,即可完成Action的配置。 **Struts2 注解配置** 1. **Action 注解** - `@Action` 用于标记一个类或方法作为 Struts2 ...
struts2_2_Action详解 共43页.pptx struts2_3_配置参数详解 共47页.pptx struts2_4_OGNL 共71页.pptx struts2_5_标签 共113页.pptx struts2_6_国际化 共34页.pptx struts2_7_数据验证 共56页.pptx struts2_8_文件...
它通过自动根据预定义的约定来配置Action,无需手动编写XML配置文件或者使用注解,极大地减少了开发者的工作量。 首先,要启用Convention插件,你需要在项目的WEB-INF/lib目录下添加struts-Convention-plugin-2.1.6...
首先,了解`@Action`注解是理解Struts2注解配置的关键。这个注解用于标记一个类或方法作为处理HTTP请求的动作。例如: ```java @Action(value = "saveUser", results = { @Result(name = "success", location = ...
在"Struts2_0100_Hell0"项目中,你将逐步学习如何创建Action类,编写配置文件,设计简单的JSP页面,以及如何在Web容器中部署和运行应用。这个简单的“Hello World!”程序是深入学习Struts2框架的起点,通过它你可以...
Struts2的注解配置主要集中在Action类和结果类型上。使用@Action注解,我们可以直接在Action类上声明其对应的URL路径,而无需在struts.xml文件中进行配置。例如: ```java @Action(value = "saveUser", results = {...
在 "Struts2_Spring_Example" 这个项目中,我们可以期待看到以下几个关键组件和配置: 1. **struts.xml**:这是 Struts2 的配置文件,定义了动作类、结果视图、拦截器等。在这个例子中,会看到如何配置 Struts2 ...