- Struts 2 教程
- Struts2 - 主页
- Struts2 - 基本 MVC 架构
- Struts2 - 概述
- Struts2 - 环境设置
- Struts2 - 架构
- Struts2 - 示例
- Struts2 - 配置
- Struts2 - 动作
- Struts2 - 拦截器
- Struts2 - 结果类型
- Struts2 - 价值堆栈/OGNL
- Struts2 - 文件上传
- Struts2 - 数据库访问
- Struts2 - 发送电子邮件
- Struts2 - 验证
- Struts2 - 本地化
- Struts2 - 类型转换
- Struts2 - 主题/模板
- Struts2 - 异常处理
- Struts2 - 注释
- Struts 2 集成
- Struts2-Spring
- Struts2 - 瓷砖
- Struts2-Hibernate
- Struts 2 有用资源
- Struts2 - 问题与解答
- Struts2 - 快速指南
- Struts2 - 有用的资源
- Struts2 - 讨论
Struts 2 - 注释
如前所述,Struts 提供两种形式的配置。传统方法是使用struts.xml文件进行所有配置。到目前为止,我们在教程中已经看到了很多这样的例子。配置 Struts 的另一种方法是使用 Java 5 注释功能。使用struts注解,我们可以实现零配置。
要开始在项目中使用注释,请确保已在WebContent/WEB-INF/lib文件夹中包含以下 jar 文件 -
- struts2-约定-插件-xyzjar
- asm-xyjar
- antlr-xyzjar
- 公共文件上传-xyzjar
- 公共 io-xyzjar
- commons-lang-xyjar
- 公共日志记录 xyzjar
- commons-logging-api-xyjar
- freemarker-xyzjar
- javassist-.xy.z.GA
- 奥格尼-xyzjar
- struts2-核心-xyzjar
- xwork-core.xyzjar
现在,让我们看看如何取消struts.xml文件中的可用配置并将其替换为注释。
为了解释 Struts2 中注释的概念,我们必须重新考虑Struts2 验证章节中解释的验证示例。
在这里,我们将以一个员工为例,其姓名、年龄将使用一个简单的页面捕获,我们将进行两次验证以确保 ÜSER 始终输入姓名,年龄应在 28 到 65 之间。
让我们从示例的主 JSP 页面开始。
创建主页
让我们编写主页面JSP文件index.jsp,用于收集上面提到的员工相关信息。
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1" pageEncoding = "ISO-8859-1"%> <%@ taglib prefix = "s" uri = "/struts-tags"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Employee Form</title> </head> <body> <s:form action = "empinfo" method = "post"> <s:textfield name = "name" label = "Name" size = "20" /> <s:textfield name = "age" label = "Age" size = "20" /> <s:submit name = "submit" label = "Submit" align="center" /> </s:form> </body> </html>
index.jsp 使用了 Struts 标签,我们还没有涉及到它,但我们将在标签相关的章节中研究它们。但现在,假设 s:textfield 标记打印输入字段,而 s:submit 打印提交按钮。我们为每个标签使用了 label 属性,它为每个标签创建标签。
创建视图
我们将使用 JSP 文件success.jsp,在定义的操作返回SUCCESS时将调用该文件。
<%@ page language = "java" contentType = "text/html; charset = ISO-8859-1" pageEncoding = "ISO-8859-1"%> <%@ taglib prefix = "s" uri = "/struts-tags"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Success</title> </head> <body> Employee Information is captured successfully. </body> </html>
创建动作
这就是使用注解的地方。让我们用注释重新定义操作类Employee,然后在Employee.java文件中添加一个名为validate()的方法,如下所示。确保您的操作类扩展了ActionSupport类,否则您的 validate 方法将不会被执行。
package com.tutorialspoint.struts2; import com.opensymphony.xwork2.ActionSupport; import org.apache.struts2.convention.annotation.Action; import org.apache.struts2.convention.annotation.Result; import org.apache.struts2.convention.annotation.Results; import com.opensymphony.xwork2.validator.annotations.*; @Results({ @Result(name = "success", Location = "/success.jsp"), @Result(name = "input", Location = "/index.jsp") }) public class Employee extends ActionSupport { private String name; private int age; @Action(value = "/empinfo") public String execute() { return SUCCESS; } @RequiredFieldValidator( message = "The name is required" ) public String getName() { return name; } public void setName(String name) { this.name = name; } @IntRangeFieldValidator(message = "Age must be in between 28 and 65", min = "29", max = "65") public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
我们在这个例子中使用了一些注释。让我一一介绍一下 -
首先,我们添加了结果注释。结果注释是结果的集合。
在结果注释下,我们有两个结果注释。结果注释的名称与执行方法的结果相对应。它们还包含一个位置,该位置应提供与execute()的返回值相对应的视图
下一个注释是Action注释。这用于装饰execute() 方法。Action 方法还接受一个值,该值是调用该操作的 URL。
最后,我使用了两个验证注释。我已经在名称字段上配置了必需的字段验证器,在年龄字段上配置了整数范围验证器。我还为验证指定了一条自定义消息。
配置文件
我们确实不需要struts.xml配置文件,所以让我们删除这个文件并检查web.xml文件的内容 -
<?xml version = "1.0" Encoding = "UTF-8"?> <web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xmlns = "http://java.sun.com/xml/ns/javaee" xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id = "WebApp_ID" version = "3.0"> <display-name>Struts 2</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <filter> <filter-name>struts2</filter-name> <filter-class> org.apache.struts2.dispatcher.FilterDispatcher </filter-class> <init-param> <param-name>struts.devMode</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
现在,右键单击项目名称,然后单击“导出”>“WAR 文件”以创建一个 War 文件。然后将此 WAR 部署到 Tomcat 的 webapps 目录中。最后,启动 Tomcat 服务器并尝试访问 URL http://localhost:8080/HelloWorldStruts2/index.jsp。这将产生以下屏幕 -
现在不要输入任何必需的信息,只需单击“提交”按钮即可。您将看到以下结果 -
输入所需信息,但在“发件人”字段中输入错误,假设姓名为“test”,年龄为 30,最后单击“提交”按钮。您将看到以下结果 -
Struts 2 注释类型
Struts 2 应用程序可以使用 Java 5 注释作为 XML 和 Java 属性配置的替代方案。您可以检查与不同类别相关的最重要注释的列表 -