`

Struts2_基于注解的Action配置

 
阅读更多

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 2使用注解配置Action"中,我们不再需要在struts.xml中为每个Action类手动添加配置。相反,我们可以在Action类或者方法上直接使用注解来声明它们的功能。这样不仅提高了代码的可读性,还使得配置更加灵活。...

    1002_____struts_____零配置

    通常,这样的文章可能会详细解释如何在实际项目中实现Struts 2的零配置,包括如何使用注解进行配置,如何配置Struts 2的拦截器,以及如何处理Action和结果页面的映射等。 标签 "源码" 暗示讨论可能涉及到对Struts 2...

    struts2_jar

    10. **注解(Annotations)**:从Struts2.1版本开始,框架支持注解配置,允许开发者在Action类和方法上使用注解替代XML配置。 以上只是Struts2框架中的一部分核心概念和特性,实际使用时还需要结合其他技术,如...

    spring_struts2_mybatis_注解的小实例

    在本项目"spring_struts2_mybatis_注解的小实例"中,我们将深入探讨如何使用SSM(Spring、Struts2、MyBatis)框架来实现一个基础的增删改查(CRUD)功能。SSM是Java Web开发中常用的三大组件,它们各自负责不同的...

    Struts2_jquery_json1.0.zip_Struts2 heloword_struts2_struts2 jque

    `struts2_helloworld`标签可能指的是一个简单的入门示例,它通常包括创建一个Action类、一个JSP页面和相关的Struts配置,以展示Struts2的基本工作流程。 总结来说,"Struts2_jquery_json1.0.zip"是一个综合实例,...

    Struts2_JSON_Demo

    在"Struts2_JSON_Demo"这个项目中,我们将看到如何在Struts2框架中集成JSON支持,以实现前后端的数据交互。以下是一些关键的知识点: 1. **Struts2 JSON插件**:Struts2提供了内置的JSON插件,允许我们直接将Action...

    struts2_api.rar_STRUTS2-API_structs2 api_struts2 api_struts2 res

    5. **Struts2配置**:Struts2的配置可以是XML(struts.xml)或基于注解的,用于定义Action、结果、拦截器栈等。文档中将详细解释如何配置这些元素以满足不同需求。 6. **OGNL(Object-Graph Navigation Language)*...

    Struts2_0500_ActionMethod

    除了使用XML配置文件,Struts2还支持使用注解进行Action方法的配置。例如,可以使用`@Action`注解来指定Action方法及其返回值: ```java @Action(value = "saveUser", results = { @Result(name = "success", ...

    struts2_action代码

    在本压缩包"Struts2_0300_Action"中,包含的是关于Struts2 Action的实践代码,这对于初学者了解和掌握Struts2框架的核心概念和工作原理非常有帮助。 首先,Action是Struts2的核心组件之一,它是业务逻辑的执行者。...

    spring_struts2_mybatis配置文件架包

    "spring_struts2_mybatis配置文件架包"提供了整合这三个框架所需的配置文件和依赖库,为开发者提供了一个快速入门的模板。这个包对于初学者来说极其有价值,因为它减少了配置工作,使他们能够更快地理解和实践这些...

    struts2_spring_mybatis

    - **配置Struts2**:配置struts2.xml,定义Action,指定Controller,同时配置结果视图。 - **配置MyBatis**:配置mybatis-config.xml,加载Mapper接口和SQL映射文件。 - **整合Spring和Struts2**:使用Spring的...

    Struts2_0300_Action.zip_action

    1. **XML配置**: 在Struts2的配置文件(struts.xml或struts.properties)中,我们需要为每个Action类指定一个唯一的namespace和actionName。例如: ```xml &lt;package name="default" namespace="/" extends="struts...

    struts2.3.4.1注解零配置

    在这个"struts2.3.4.1注解零配置"的例子中,我们将深入探讨如何利用Struts2的注解来构建一个简单的登录系统。 首先,了解Struts2的核心概念是必要的。Struts2是一个基于MVC(Model-View-Controller)设计模式的框架...

    Struts2+spring注解配置

    Struts2 提供了一种使用注解替代 XML 配置的方式,使得开发者无需编写繁琐的 struts.xml 文件,即可完成Action的配置。 **Struts2 注解配置** 1. **Action 注解** - `@Action` 用于标记一个类或方法作为 Struts2 ...

    Java实训教程 Java软件开发实战 Java开发框架介绍 struts2 SpringMVC等共20多份课件资料.rar

    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_文件...

    简述STRUTS2_Convention零配置

    它通过自动根据预定义的约定来配置Action,无需手动编写XML配置文件或者使用注解,极大地减少了开发者的工作量。 首先,要启用Convention插件,你需要在项目的WEB-INF/lib目录下添加struts-Convention-plugin-2.1.6...

    Struts2之Annotation注解配置使用案例struts013

    首先,了解`@Action`注解是理解Struts2注解配置的关键。这个注解用于标记一个类或方法作为处理HTTP请求的动作。例如: ```java @Action(value = "saveUser", results = { @Result(name = "success", location = ...

    Struts2_0100_Hell0

    在"Struts2_0100_Hell0"项目中,你将逐步学习如何创建Action类,编写配置文件,设计简单的JSP页面,以及如何在Web容器中部署和运行应用。这个简单的“Hello World!”程序是深入学习Struts2框架的起点,通过它你可以...

    Struts2+spring注解配置简介

    Struts2的注解配置主要集中在Action类和结果类型上。使用@Action注解,我们可以直接在Action类上声明其对应的URL路径,而无需在struts.xml文件中进行配置。例如: ```java @Action(value = "saveUser", results = {...

    Struts2_Spring_Example.zip_spring struts2_struts2-examp

    在 "Struts2_Spring_Example" 这个项目中,我们可以期待看到以下几个关键组件和配置: 1. **struts.xml**:这是 Struts2 的配置文件,定义了动作类、结果视图、拦截器等。在这个例子中,会看到如何配置 Struts2 ...

Global site tag (gtag.js) - Google Analytics