📅  最后修改于: 2020-11-11 05:02:41             🧑  作者: Mango
协议将HTTP请求上的所有内容都视为字符串。这包括数字,布尔值,整数,日期,小数等。但是,在Struts类中,您可以具有任何数据类型的属性。
Struts如何为您自动连接属性?
Struts在盖板下使用各种类型的转换器来进行繁重的工作。
例如,如果您的Action类中有一个integer属性,则Struts会自动将请求参数转换为integer属性,而无需您进行任何操作。默认情况下,Struts带有许多类型转换器
如果您使用下面列出的任何转换器,那么您无需担心-
有时,在使用自己的数据类型时,有必要添加自己的转换器以使Struts在显示之前知道如何转换这些值。考虑以下POJO类Environment.java 。
package com.tutorialspoint.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.tutorialspoint.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,以显示环境和操作系统信息。
System Details
Environment:
Operating System:
让我们使用struts.xml将system.jsp和SystemDetails.java类连接在一起。
SystemDetails类具有一个简单的execute()方法,该方法返回字符串“ SUCCESS ”。
/System.jsp
右键单击项目名称,然后单击导出> WAR文件以创建War文件。
然后,将此WAR部署在Tomcat的webapps目录中。
最后,启动Tomcat服务器并尝试访问URL http:// localhost:8080 / HelloWorldStruts2 / system.action 。这将产生以下屏幕-
上面的输出有什么问题? Struts知道如何显示和转换字符串“ Windows XP SP3”和其他内置数据类型,但是它不知道如何处理Environment类型的属性。在类上简称为toString()方法
要解决此问题,现在让我们为Environment类创建并注册一个简单的TypeConverter 。
使用以下代码创建一个名为EnvironmentConverter.java的类。
package com.tutorialspoint.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类,并通过覆盖convertFromString()和convertToString()两个方法,告诉Struts如何将Environment转换为String,反之亦然。
现在让我们注册该转换器,然后再在应用程序中使用它。有两种注册转换器的方法。
如果仅在特定操作中使用转换器,则必须创建一个属性文件,该文件需要命名为‘[action-class]’converstion.properties 。
在我们的例子中,我们使用以下注册条目创建一个名为SystemDetails-converstion.properties的文件-
environment = com.tutorialspoint.struts2.EnvironmentConverter
在上面的示例中,“ environment”是SystemDetails.java类中属性的名称,并且我们告诉Struts使用EnvironmentConverter在该属性之间进行转换。
但是,我们不会这样做,而是将在全球范围内注册此转换器,以便可以在整个应用程序中使用它。为此,请使用以下行在WEBINF / classes文件夹中创建一个名为xwork-conversion.properties的属性文件。
com.tutorialspoint.struts2.Environment = \
com.tutorialspoint.struts2.EnvironmentConverter
这只是在全局范围内简单地注册转换器,以便Struts每次遇到环境类型的对象时都可以自动进行转换。现在,如果您重新编译并重新运行该程序,则将获得更好的输出,如下所示:
显然,现在结果会更好,这意味着我们的Struts转换器运行良好。
这样便可以创建多个转换器并注册它们以根据需要使用。