class Person{
String firstName;
String lastName;
String email;
}
<person>
<firstName value="asd" />
<lastName value="bcd" />
<email value="qwe" />
</person>
谢了!
您可以使用XmlAdapter
,如下所示:
import java.io.*;
import javax.xml.bind.*;
import javax.xml.bind.annotation.*;
import javax.xml.bind.annotation.adapters.*;
@XmlType
class Valued {
@XmlAttribute(name="value")
public String value;
}
class ValuedAdapter extends XmlAdapter<Valued, String> {
public Valued marshal(String s) {
Valued v = new Valued();
v.value = s;
return v;
}
public String unmarshal(Valued v) {
return v.value;
}
}
@XmlRootElement
class Person {
@XmlJavaTypeAdapter(ValuedAdapter.class)
@XmlElement
String firstName;
@XmlJavaTypeAdapter(ValuedAdapter.class)
@XmlElement
String lastName;
}
class SO12928971 {
public static void main(String[] args) throws Exception {
Person p = new Person();
p.firstName = "John";
p.lastName = "Doe";
JAXBContext jc = JAXBContext.newInstance(Person.class);
StringWriter sw = new StringWriter();
jc.createMarshaller().marshal(p, sw);
String xml = sw.toString();
System.out.println(xml);
StringReader sr = new StringReader(xml);
p = (Person)jc.createUnmarshaller().unmarshal(sr);
assert "John".equals(p.firstName);
assert "Doe".equals(p.lastName);
}
}
这里的思想是,XML Schema以及JAXB在元素名称和内容类型之间有明显的区别,尽管许多文档在这两者之间有明显的一一对应关系。因此,在上面的代码中,类型value
描述具有value
属性的东西,而不考虑元素名称。要序列化的成员被注释为@xmlelement
,注释中不包含名称。因此,它们将生成具有从成员名称派生的名称的元素。@XMLJavaTypeAdapter
注释将导致序列化程序将这些成员视为它们的类型为值
。因此,这就是它们的XML内容类型。
上面代码的模式如下所示:
<xs:schema version="1.0" xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="person" type="person"/>
<xs:complexType name="person">
<xs:sequence>
<xs:element name="firstName" type="valued" minOccurs="0"/>
<xs:element name="lastName" type="valued" minOccurs="0"/>
</xs:sequence>
</xs:complexType>
<xs:complexType name="valued">
<xs:sequence/>
<xs:attribute name="value" type="xs:string"/>
</xs:complexType>
</xs:schema>
问题内容: 有没有一种方法可以指定JAXB在XML模式中用于编组/解编对象的适配器? 例如,如果我想将以下内容解析为整数: 我可以在架构中使用以下内容: 当我通过XJC工具运行模式时,应使用Integer.decode()作为值为0x1234的Integer或十进制4660来解码字符串“ 0x1234”。生成的Adapter类正确反映了这一点: 但是,当我想将值编组回XML元素(这是String文
如何通过注释而不是常规配置文件配置入站通道适配器?我可以为会话工厂定义bean,如下所示: 如何配置通过注释下给出的入站通道适配器? 我正在寻找的是在应用程序启动时连接所有bean,然后公开一些方法来开始轮询服务器,处理它们,然后从本地删除它们,类似于 其中getPollableChannel()为我提供了用于轮询的bean。
问题内容: 我有一个返回此XML的服务: 要么 我想使用以下类解组检索到的XML: 结果 : 项目名称 : 用户名 : 首先不起作用的解决方案 我得到一个空名单。 第二不起作用的解决方案 受本文启发,http://blog.bdoughan.com/2012/11/creating-generic-list-wrapper-in- jaxb.html 我修改了Response类: 然后使用以下代码
我有一个模型对象,它是在多次转换和解析之后填充的。现在,我需要使用spring集成将模型中的消息属性发送给kafka。我可以使用messageKey方法构造键,但如何从m.getPayload()之类的模型中获取实际消息。getMessage()并将其发送给Kafka。
如果我创建一个SFTP入站通道适配器,并使用在SFTP中配置为channel属性的通道发送一些文件。文件将传输到SFTP远程目录本地目录,还是直接从通道流到本地目录
适配器是一种特殊的库,它有一个父类和任意数量的子类。子类可以访问其父类元素,但不能访问其兄弟类的元素。在你的控制器中,适配器为类库提供了一种优雅的语法,因此类库会就此获益甚至会需要分解成离散的类。 适配器的源文件存放在system/libraries 目录下, 命名一个和类名字相同的文件夹,文件夹下存放该类。同时在该文件夹中,有一个子文件夹叫做 drivers在其中包含了所有的子类。 要使用一个适