我正在创建一个java应用程序来检查一个XML文件是否已经是规范的,或者没有使用XOM。
在我的测试中,我有以下文件,该文件已经是规范化的。
<doc xmlns="http://example.com/default" xmlns:x="http://example.com/x">
<a a1="1" a2="2">123</a>
<b xmlns:y="http://example.com/y" a3=""3"" y:a1="1" y:a2="2"></b>
</doc>这里是我再次用XOM加载它时的代码。
<?xml version="1.0"?>
<doc xmlns="http://example.com/default" xmlns:x="http://example.com/x">
<a a1="1" a2="2">123</a>
<b xmlns:y="http://example.com/y" a3=""3"" y:a1="1" y:a2="2" />
</doc>如您所见,它再次添加xml标记并删除结束标记</b>,因为标记b的值为空。xml标记没有任何问题,但是当我从文件中加载规范文档时,我不知道如何保持结束标记</b>。
发布于 2012-04-18 09:25:55
看起来,您要用XOM串行化输出文档,您需要使用XOM规范化器输出xml文档并保持其规范化。
这给出了输出:
<?xml version="1.0" encoding="UTF-8"?>
<doc xmlns="http://example.com/default" xmlns:x="http://example.com/x">
<a a1="1" a2="2">123</a>
<b a3=""3"" y:a1="1" y:a2="2" xmlns:y="http://example.com/y"/>
</doc>下面的示例程序将使用System.out将XML戛纳输出到XOM规范化器
package com.foo.bar.xom;
import java.io.IOException;
import nu.xom.Builder;
import nu.xom.canonical.Canonicalizer;
import nu.xom.Document;
import nu.xom.ParsingException;
import nu.xom.Serializer;
import nu.xom.ValidityException;
public class App
{
public static void main(String[] args) throws ValidityException, ParsingException, IOException
{
Builder builder = new Builder();
//Serializer serializer = new Serializer(System.out);
Canonicalizer canonicalizer = new Canonicalizer(System.out, Canonicalizer.EXCLUSIVE_XML_CANONICALIZATION);
//this assumes to your xml document is on the classpath in this package as my.xml
Document input = builder.build(App.class.getResourceAsStream("my.xml"), null);
//serializer.write(input);
canonicalizer.write(input);
}
}https://stackoverflow.com/questions/6370085
复制相似问题