我正在尝试使用JAXB规范的MOxy实现。其中一个主要原因是确保在封送对象内容期间不会丢失XML文件中未映射的元素。即使(我认为)我在正确的位置有jaxb.properties文件,我一直在击中ClassCastException。以下是我的文件组织(以及它在Eclipse中的组织方式):
我编写了一些基本的东西来验证此实现的功能。
import java.io.File;
import javax.xml.bind.Binder;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.eclipse.persistence.jaxb.JAXBContext;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
public class zMain {
public static void main(String[] args) {
try {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
File xml = new File("sampleconfig.xml");
Document document = db.parse(xml);
JAXBContext jc = JAXBContext.newInstance(Config.class);
Binder<Node> binder = jc.createBinder();
Config cfg = (Config) binder.unmarshal(document);
// do nothing
binder.updateXML(cfg);
TransformerFactory tf = TransformerFactory.newInstance();
Transformer t = tf.newTransformer();
t.setOutputProperty(OutputKeys.INDENT, "yes");
t.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "3");
t.transform(new DOMSource(document), new StreamResult(System.out));
} catch (Exception ex) {
ex.printStackTrace();
System.exit(100);
}
}
}
执行此JAR会抛出
java.lang.ClassCastException: com.sun.xml.internal.bind.v2.runtime.JAXBContextImpl cannot be cast to org.eclipse.persistence.jaxb.JAXBContext
eclipselink-2.4.0.jar在我的类路径中(否则我假设它会是ClassNotFoundException或编译错误)。
虽然不太可能,但是否有任何环境设置会导致我的导入被覆盖?关于这里做错了什么的任何指示都会有很大的帮助。
感谢。
答案 0 :(得分:2)
在您的示例中,jaxb.properties
文件必须与Config
类位于同一个包中。
解决当前问题后,以下导入会导致问题。 JAXBContext.newInstance(Config.class)
将返回javax.xml.bind.JAXBContext
的实例,因此您应该将其导入。
import org.eclipse.persistence.jaxb.JAXBContext;
以下是GitHub示例的链接,该示例利用jaxb.properties
文件将MOXy指定为JAXB提供程序。
了解更多信息
注意:强>
当前版本的EclipseLink是2.4.1,您可以从以下位置下载它: