3

让我解释一下我的场景,我有一个接受 xml 请求并做出响应的 Web 应用程序。我使用 jaxb 解析请求,将其转换为我的应用程序 dao 对象,处理请求,然后将 dao 结果重新转换为 jaxb 对象并返回。现在我必须支持多个版本(不同的 xml 版本可以作为请求,我必须用合适的 xml 响应来响应)。我为 jaxb 对象生成 java 文件-> dao 对象转换器和反向。问题是在转换为我的 dao 对象之前,会创建 jaxb 对象,然后在将其传递给我的转换器之前对其进行验证。我不确定在这里应用什么设计模式。可能是适配器模式。请建议?如果我也可能必须生成 jaxb 编组和非编组代码,还要抛出灯吗?

4

1 回答 1

2

希望我能很好地理解你的问题。所以你已经有:

xml 1 ---> jaxb objects 1 ---> converter 1 ---> entity objects

现在您需要适应一种新的 xml 格式。

为此,您可以编写一个新的转换器来支持新格式:

xml 2 ---> jaxb objects 2 ---> converter 2 ---> entity objects

或编写一些 xml 适配器以使新的 jaxb 对象适应第一种格式:

xml 2 ---> jaxb objects 2 ---> adapter ---> jaxb objects 1 ---> converter 1 ---> entity objects

我建议第一种方法:编写一个新的转换器,以便新格式不依赖于第一个格式(以防可能需要停用第一种格式)。

转换器将自身与 jaxb 对象混合,作为实体对象的包装器以及@XmlJavaTypeAdapter复杂类型。一个非常简单的例子:

public class XmlPerson {
    private Person person;

    public XmlPerson(Person person) {
        this.person = person;
    }

    public XmlPerson() {
        this.person = new Person();
    }

    public Person getPerson() {
    }

    public String getFirstName() {
        return person.getFristname();
    }

    public void setFirstname(String firstName) {
        person.setFirstName(firstName);
    }

    ....

    @XmlJavaTypeAdapter(XmlAddressAdapter.class)
    public Address getAddress() {
        return person.getAddress();
    }

    public void setAddress(Address address) {
        person.setAddress(address);
    }
}

应该本身从a@XmlJavaTypeAdapter适应(转换)Address到 a XmlAddress

public class XmlAddressAdapter extends XmlAdapter<XmlAddress, Address> {
    @Override
    public Address unmarshal(XmlAddress xmlAddress) throws Exception {
        return xmlAddress.getAddress();
    }

    @Override
    public XmlAddress marshal(Address address) throws Exception {
        return address != null ? new XmlAddress(address) : null;
    }
}

如果我也可能必须生成 jaxb 编组和非编组代码,还要抛出灯吗?

您只需将 xml 对象传递给编组器并xsd使用解组器验证您可能已经在做的事情:

元帅:

   JAXBContext jaxbContext = JAXBContext.newInstance(XmlPerson.class);
   Marshaller jaxbMarshaller = jaxbContext.createMarshaller();
   jaxbMarshaller.marshal(xmlPerson, output);

解组:

JAXBContext jaxbContext = JAXBContext.newInstance(targetClass);
Unmarshaller jaxbUnmarshaller = jaxbContext.createUnmarshaller();

SchemaFactory sf = SchemaFactory.newInstance(
                    javax.xml.XMLConstants.W3C_XML_SCHEMA_NS_URI);
Schema schema = sf.newSchema(XmlInvoice.class.getResource("/yourXsd.xsd"));
jaxbUnmarshaller.setSchema(schema);

Object unmarshalResult = jaxbUnmarshaller.unmarshal(inputStream);
于 2012-08-25T06:54:42.600 回答