考虑两个同构 XML 模式。这里的同构是指这两个模式除了属性和标签名称之外具有相同的结构。更具体地说,我有一个实例,当模式是 A
时,及其副本 B
,其中所有标签和属性名称都从英语翻译成国家语言等效项。
例如,作为输入,我们可以有一个对象的两种不同变体:
<tag_1_v1>
<tag_2_v1 id="blabla" name="xxxxx">
Some value1
</tag_2_v1>
<tag_3_v1 id="alalala" name="yyyyy">
Some value2
</tag_3_v1>
</tag_1_v1>
和
<tag_1_v2>
<tag_2_v2 special_id_2="blabla" name="xxxxx">
Some value1
</tag_2_v2>
<tag_3_v2 id="alalala" special_name_2="yyyyy">
Some value2
</tag_3_v2>
</tag_1_v2>
问题是将这两个模式映射到单个类结构上,例如
class Tag1 {
Tag2 tag2;
Tag3 tag3;
}
class Tag2 {
String id;
String name;
String value;
}
class Tag3 {
String id;
String name;
String value;
}
有多种想法可以解决此问题,但所有这些想法都不是那么方便,因为有可能在同一类结构上使用单个 JAXB 注释方案。他们是:
- 创建两个不同的类集,然后从对象中复制值 将一种模式转变为另一种模式;
- 创建自己的 SAX 解析器实现并将其内部标签和属性名称“翻译”为适当的名称;
- 使用自己的 XML 预处理器并使用字符串替换(如果所有架构中的 id 和属性名称不相同,则不起作用)。
最佳答案
自每个<tag_i>
可以有不同的属性,一个干净的解决方案是使用继承:
- 创建一个抽象类
Tag1
由Tag1V1
继承和Tag1V2
。将所有公共(public)代码分解为Tag1
. - 同样的情况
Tag2
和Tag3
.
为了帮助您入门,这里是 Tag2
的实现:
@XmlRootElement
@XmlSeeAlso({Tag2V1.class, Tag2V2.class})
abstract class Tag2 {
private String name;
private String content;
@XmlAttribute(name = "name")
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@XmlValue
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
}
@XmlRootElement(name = "tag_2_v1")
class Tag2V1 extends Tag2 {
private String id;
@XmlAttribute(name = "id")
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
@XmlRootElement(name = "tag_2_v2")
class Tag2V2 extends Tag2 {
private String specialId2;
@XmlAttribute(name = "special_id_2")
public String getSpecialId2() {
return specialId2;
}
public void setSpecialId2(String specialId2) {
this.specialId2 = specialId2;
}
}
关于java - 使用 JAXB 将两个同构 XML 模式解析为一个类结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33604945/