题
.NET 的 XML 序列化的 Java 类似物是什么?
解决方案
2008年答案用于此目的的“官方”Java API 现在是 JAXB - 用于 XML 绑定的 Java API。看 Oracle 教程. 。参考实现位于 http://jaxb.java.net/
2018年更新 注意 Java EE 和 CORBA 模块在 JDK9 的 SE 中已弃用,并将在 JDK11 的 SE 中删除. 。因此,要使用 JAXB,它需要位于您现有的企业级环境中,例如由您的企业捆绑在一起。应用程序服务器,否则您需要手动将其引入。
其他提示
流媒体 非常擅长将对象序列化为 XML,无需太多配置和金钱!(它是在 BSD 许可下)。
我们在我们的一个项目中使用它来替换普通的旧 java 序列化,它几乎可以开箱即用。
“简单 XML 序列化”项目
您可能想看看 简单的 XML 序列化 项目。这是我发现的最接近 .Net 中的 System.Xml.Serialization 的东西。
JAXB 是 JDK 标准版 1.6+ 的一部分。原来如此 FREE
无需下载和管理额外的库。可以找到一个简单的例子 这里
XStream 似乎已经死了。最后更新时间为 2008 年 12 月 6 日。Simple
看起来像 JAXB 一样简单,但我找不到任何许可信息来评估它是否适合企业使用。
值得一提的是,从 1.4 版开始,Java 有了 java.beans.XMLEncoder 和 java.beans.XMLDecoder 类。这些类执行 XML 编码,这至少与 XML 序列化非常相似,并且在某些情况下可能适合您。
如果您的类的 getter 和 setter 遵循 JavaBeans 规范,则此方法使用起来很简单,并且不需要模式。但有以下注意事项:
- 与普通的 Java 序列化一样
- 通过输入流和输出流进行编码和解码
- 该过程使用熟悉的 writeObject 和 readObject 方法
- 与普通的 Java 序列化相比
- 编码和解码都会导致构造函数和初始值设定项被调用
- 无论您的类是否实现 Serialized,编码和解码都可以工作
- 不考虑瞬态修饰符
- 仅适用于具有公共构造函数的公共类
例如,采用以下声明:
public class NPair {
public NPair() { }
int number1 = 0;
int number2 = 0;
public void setNumber1(int value) { number1 = value;}
public int getNumber1() { return number1; }
public void setNumber2(int value) { number2 = value; }
public int getNumber2() {return number2;}
}
执行这段代码:
NPair fe = new NPair();
fe.setNumber1(12);
fe.setNumber2(13);
FileOutputStream fos1 = new FileOutputStream("d:\\ser.xml");
java.beans.XMLEncoder xe1 = new java.beans.XMLEncoder(fos1);
xe1.writeObject(fe);
xe1.close();
将产生以下文件:
<?xml version="1.0" encoding="UTF-8"?>
<java version="1.7.0_02" class="java.beans.XMLDecoder">
<object class="NPair">
<void property="number1">
<int>12</int>
</void>
<void property="number2">
<int>13</int>
</void>
</object>
</java>
XMLBeans 如果您有 XML 架构,那么效果会很好。它为模式创建 Java 对象并创建易于使用的解析方法。
如果您正在谈论对象的自动 XML 序列化,请查看 蓖麻:
Castor 是 Java[tm] 的开源数据绑定框架。它是 Java 对象、XML 文档和关系表之间的最短路径。Castor 提供 Java 到 XML 的绑定、Java 到 SQL 的持久性等。
别忘了 吉宝新.
如果你想要一个 结构化解决方案 (像 ORM)那么 JAXB2 是一个很好的解决方案。
如果你想要像 DOT NET 这样的序列化,那么你可以使用 JavaBeans 组件的长期持久性
选择取决于序列化的使用。
public static String genXmlTag(String tagName, String innerXml, String properties )
{
return String.format("<%s %s>%s</%s>", tagName, properties, innerXml, tagName);
}
public static String genXmlTag(String tagName, String innerXml )
{
return genXmlTag(tagName, innerXml, "");
}
public static <T> String serializeXML(List<T> list)
{
String result = "";
if (list.size() > 0)
{
T tmp = list.get(0);
String clsName = tmp.getClass().getName();
String[] splitCls = clsName.split("\\.");
clsName = splitCls[splitCls.length - 1];
Field[] fields = tmp.getClass().getFields();
for (T t : list)
{
String row = "";
try {
for (Field f : fields)
{
Object value = f.get(t);
row += genXmlTag(f.getName(), value == null ? "" : value.toString());
}
} catch (IllegalAccessException e) {
e.printStackTrace();
}
row = genXmlTag(clsName, row);
result += row;
}
}
result = genXmlTag("root", result);
return result;
}