标签:多个 1.0 https 日期 exe 工作 XML action 练习
在HTTP请求中的一切都被视为一个String由协议。这包括数字,布尔值,整数,日期,小数和一切。每一件事情是一个字符串,将根据HTTP。然而,Struts类可以有任何数据类型的属性。Struts的自动装配属性?
Struts使用了多种类型转换器在幕后做繁重。例如,如果Action类的属性有一个整数,Struts的自动转换请求参数的整数属性没有做任何事情。默认情况下,Struts的一些类型转换器。下面列出了他们中的一些,如果您正在使用其中任何一个,那么你有什么可担心的:
Integer, Float, Double, Decimal
Date and Datetime
Arrays and Collections
Enumerations
Boolean
BigDecimal
有些时候,当使用自己的数据类型,它是需要添加自己的转换,使Struts知道如何将这些值,然后显示。考虑以下POJO类Environment.java。
package com.yiibai.struts2;
public class Environment {
private String name;
public Environment(String name)
{
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
这是一个非常简单的类,它有一个名为name的属性,所以没有什么特别的关于这个类。我们创建包含有关系统 - SystemDetails.java信息另一个类。目的是练习,我有硬编码环境,以“开发”在操作系统“Windows XP SP3”。在实际项目中,会从系统配置得到信息。因此,让我们有以下动作类:
package com.yiibai.struts2;
import com.opensymphony.xwork2.ActionSupport;
public class SystemDetails extends ActionSupport {
private Environment environment = new Environment("Development");
private String operatingSystem = "Windows XP SP3";
public String execute()
{
return SUCCESS;
}
public Environment getEnvironment() {
return environment;
}
public void setEnvironment(Environment environment) {
this.environment = environment;
}
public String getOperatingSystem() {
return operatingSystem;
}
public void setOperatingSystem(String operatingSystem) {
this.operatingSystem = operatingSystem;
}
}
接下来让我们创建一个简单的JSP文件System.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>System Details</title>
</head>
<body>
Environment: <s:property value="environment"/><br/>
Operating System:<s:property value="operatingSystem"/>
</body>
</html>
让我们编写 system.jsp,SystemDetails.java类在struts.xml一起使用。 SystemDetails类有一个简单的execute()方法返回字符串“SUCCESS”。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.devMode" value="true" />
<package name="helloworld" extends="struts-default">
<action name="system"
class="com.yiibai.struts2.SystemDetails"
method="execute">
<result name="success">/System.jsp</result>
</action>
</package>
</struts>
右键点击项目名称,并单击 Export > WAR File 创建一个WAR文件。然后部署此WAR在Tomcat的webapps目录下。最后,启动Tomcat服务器和尝试访问URL http://localhost:8080/HelloWorldStruts2/system.action。这会给出以下画面:
上面的输出有什么错? Struts 知道如何显示字符串“Windows XP SP3”等内置数据类型转换,但它不知道用Environmenttype属性做什么。所以,它只是被称为类的toString()方法。为了解决这个问题,现在让我们创建并注册一个简单的TypeConverter环境类。创建一个类名为EnvironmentConverter.java以下。
package com.yiibai.struts2;
import java.util.Map;
import org.apache.struts2.util.StrutsTypeConverter;
public class EnvironmentConverter extends StrutsTypeConverter {
@Override
public Object convertFromString(Map context, String[] values,
Class clazz) {
Environment env = new Environment(values[0]);
return env;
}
@Override
public String convertToString(Map context, Object value) {
Environment env = (Environment) value;
return env == null ? null : env.getName();
}
}
EnvironmentConverter 扩展了 StrutsTypeConverter 类,如何将环境为一个 String,反之亦然通过重写两个的方法 convertFromString()和 convertToString()并通知了Struts。现在,让我们注册这个转换器之前,我们我们在我们的应用程序。有两种方法来注册一个转换器。如果转换器将只用于在一个特定的动作,那么将需要创建一个属性文件需要被命名为 ‘[action-class]‘-converstion.properties,所以,在我们的例子中,我们创建一个名为SystemDetails下面的注册 converstion.properties 输入:
environment=com.yiibai.struts2.EnvironmentConverter
在上面的例子中,“environment”的名字是在SystemDetails.java 类的一个属性,告诉要使用Struts EnvironmentConverter从这个属性的转换。但是,我们不打算这样做,相反,我们要在全局范围内注册这个转换器,因此,它可以在整个应用程序。要做到这一点,创建一个属性文件名为 xwork-conversion.properties 在 WEB-INF/classes文件夹下面一行:
com.yiibai.struts2.Environment =
com.yiibai.struts2.EnvironmentConverter
这简单的注册全局转换器,这样的Struts可以自动做转换每次遇到一个对象类型的环境。现在,如果重新编译并重新运行该程序,会得到更好的输出如下:
很显然,现在的结果是更好的,这意味着我们的Struts的转换工作正常。这是可以创建多个转换器和按要求注册后才能使用。
标签:多个 1.0 https 日期 exe 工作 XML action 练习
原文地址:https://www.cnblogs.com/pingxin/p/p00011.html