struts 2 注解——迹忆客-ag捕鱼王app官网
如前所述,struts 提供了两种配置形式。 传统方式是使用 struts.xml 文件进行所有配置。 到目前为止,我们已经在教程中看到了很多这样的例子。 配置 struts 的另一种方法是使用 java 5 annotations 特性。 使用struts注解,我们可以实现零配置。
要开始在项目中使用注解,请确保我们已在 web/web-inf/lib 文件夹中包含以下 jar 文件
- struts2-convention-plugin-x.y.z.jar
- asm-x.y.jar
- antlr-x.y.z.jar
- commons-fileupload-x.y.z.jar
- commons-io-x.y.z.jar
- commons-lang-x.y.jar
- commons-logging-x.y.z.jar
- commons-logging-api-x.y.jar
- freemarker-x.y.z.jar
- javassist-.xy.z.ga
- ognl-x.y.z.jar
- struts2-core-x.y.z.jar
- xwork-core.x.y.z.jar
现在,让我们看看如何取消 struts.xml 文件中可用的配置并将其替换为注解。
为了解释 struts2 中注解的概念,我们必须重新考虑我们在 struts2 验证 章节中解释的验证示例。
在这里,我们将举一个员工的例子,其姓名、年龄将使用一个简单的页面捕获,我们将进行两次验证来确保用户必须输入姓名,并且年龄应在 28 到 65 之间。
让我们从示例的主 jsp 页面 index.jsp 开始。用于收集上面提到的 employee 相关信息。
<%@ page contenttype="text/html;charset=utf-8" language="java" %>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
hello 迹忆客(jiyik.com)
index.jsp 使用了 struts 标签,我们还没有介绍,但我们将在标签相关的章节中研究它们。 但是现在,只假设 s:textfield
标记打印一个输入字段,而 s:submit
打印一个提交按钮。 我们为每个标签使用了标签属性,为每个标签创建标签。
创建视图
我们将使用 jsp 文件 success.jsp,如果定义的操作返回 success
,将调用该文件。
<%@ page language = "java" contenttype = "text/html; charset = iso-8859-1"
pageencoding = "iso-8859-1"%>
<%@ taglib prefix = "s" uri = "/struts-tags"%>
success
employee information is captured successfully.
创建 action
这是使用注解的地方。 让我们用注解重新定义动作类 employee,然后在 employee.java 文件中添加一个名为 validate() 的方法,如下所示。 确保我们的操作类继承了 actionsupport 类,否则我们验证方法将不会被执行。
package com.jiyik.struts2.action;
import com.opensymphony.xwork2.actionsupport;
import com.opensymphony.xwork2.validator.annotations.intrangefieldvalidator;
import com.opensymphony.xwork2.validator.annotations.requiredfieldvalidator;
import org.apache.struts2.convention.annotation.action;
import org.apache.struts2.convention.annotation.result;
import org.apache.struts2.convention.annotation.results;
@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")
@override
public string execute() {
return success;
}
public string getname() {
return name;
}
public int getage() {
return age;
}
@requiredstringvalidator(message = "姓名不能为空")
public void setname(string name) {
this.name = name;
}
@intrangefieldvalidator(message = "年龄必须在 28 至 65 岁之间" , min = "28", max = "65")
public void setage(int age) {
this.age = age;
}
}
在此示例中,我们使用了很少的注解。 让我们一一介绍
- 首先,我们已经包含了 results 注解。 results 注解是 result 的集合。
- 在 results 注解下,我们有两个 result 注解。 result 注解的名称与执行方法的结果相对应。 它们还包含一个位置,location 对应于 execute() 的返回值应提供哪个视图
- 下一个注解是 action 注解。 这用于装饰 execute() 方法。 action 方法还接受一个值,该值是调用该操作的 url。
- 最后,我使用了两个验证注解。 我已经在名称字段上配置了必填字段验证器,在年龄字段上配置了整数范围验证器。 我还为验证指定了一条自定义消息。
配置文件
我们确实不需要 struts.xml 配置文件,所以让我们删除这个文件,让我们检查 web.xml 文件的内容
struts 2
index.jsp
struts2
org.apache.struts2.dispatcher.filter.strutsprepareandexecutefilter
struts.devmode
true
struts2
/*
我们是用 idea 启动项目。项目启动成功后,我们访问 http://localhost:8080
显示界面如下所示
现在不要输入任何信息,只需单击 submit 按钮。 我们将看到以下结果
输入所需的信息, name 为“test”,age 为 30,最后点击 submit 按钮。 我们将看到以下结果
struts 2 注释类型
struts 2 应用程序可以使用 java 5 注解作为 xml 和 java 属性配置的替代方案。 我们可以查看与不同类别相关的最重要注解列表