3

我在 Oracle Weblogic 10.3.6 上运行 Dozer 5.3.2 时遇到问题。如果我在容器中运行 Dozer,则会发生以下异常。在我的 JUnit 测试中,Dozer 工作正常。

java.lang.IllegalArgumentException   
oracle.xml.jaxp.JXDocumentBuilderFactory.setAttribute(JXDocumentBuilderFactory.java:147) 
weblogic.xml.jaxp.RegistryDocumentBuilderFactory.setAttribute(RegistryDocumentBuilderFactory.java:176) 
org.dozer.loader.xml.XMLParserFactory.createDocumentBuilderFactory(XMLParserFactory.java:56) 
org.dozer.loader.xml.XMLParserFactory.createParser(XMLParserFactory.java:35) 
org.dozer.loader.xml.MappingFileReader.<init>(MappingFileReader.java:46) 
org.dozer.loader.CustomMappingsLoader.<init>(CustomMappingsLoader.java:52) 
org.dozer.DozerBeanMapper.loadCustomMappings(DozerBeanMapper.java:212) 
org.dozer.DozerBeanMapper.getMappingProcessor(DozerBeanMapper.java:186) 
org.dozer.DozerBeanMapper.map(DozerBeanMapper.java:111) 
myProject.myObject.MyDefaultMapper.map(MyDefaultMapper.java:23) 
myProject.myObject.mapToClientDS(XYZService.java:162) 
myProject.myObject.read(XYZService.java:42) 
myProject.myObject.search(MyController.java:64) 
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
java.lang.reflect.Method.invoke(Method.java:597) 
com.sun.el.parser.AstValue.invoke(Unknown Source) 
com.sun.el.MethodExpressionImpl.invoke(Unknown Source) 
oracle.adf.controller.internal.util.ELInterfaceImpl.invokeMethod(ELInterfaceImpl.java:173) 
.... 
weblogic.work.ExecuteThread.run(ExecuteThread.java:178)

问题似乎是以下方法org.dozer.loader.xml.XMLParserFactory

private DocumentBuilderFactory createDocumentBuilderFactory() { DocumentBuilderFactory     
factory = DocumentBuilderFactory.newInstance(); 
factory.setValidating(true); 
factory.setNamespaceAware(true); 
factory.setIgnoringElementContentWhitespace(true); 
factory.setAttribute(SCHEMA_FEATURE, true); // For Xerces implementation 
return factory; }

此方法设置factory.setAttribute(SCHEMA_FEATURE, true). Oracle 实现不支持该属性SCHEMA_FEATURE并抛出IllegalArgumentException包括以下堆栈跟踪:

oracle.xml.jaxp.JXDocumentBuilderFactory.setAttribute(JXDocumentBuilderFactory.java:147) 
weblogic.xml.jaxp.RegistryDocumentBuilderFactory.setAttribute(RegistryDocumentBuilderFactory.java:176)

我还尝试用 Xerces 替换 JAXP 的 oracle 实现。我通过配置Xerces 库并将其添加到已部署的库中来完成此操作<prefer-web-inf-classes>true</prefer-web-inf-classes>WEB-INF/weblogic.xml但是,如果我尝试替换我在部署应用程序时收到以下异常的库。我已经尝试过 Xerces 2.11.0 (JAXP 1.4) 和 Xerces 2.9.1 (JAXP 1.3,它应该是 Weblogic 10.3.6 的正确替代品)。( xercesImpl.jar, xml-apis.jar)

Caused By: java.lang.NoSuchMethodError: 

org.apache.xerces.impl.xpath.regex.RegularExpression.<init>(Ljava/lang/String;Ljava/lang/String;Ljava/util/Locale;)V at 

org.apache.xerces.impl.dv.xs.XSSimpleTypeDecl.applyFacets(Unknown Source) at 

org.apache.xerces.impl.dv.xs.XSSimpleTypeDecl.applyFacets1(Unknown Source) at 

org.apache.xerces.impl.dv.xs.BaseSchemaDVFactory.createBuiltInTypes(Unknown Source) at 

org.apache.xerces.impl.dv.xs.SchemaDVFactoryImpl.createBuiltInTypes(Unknown Source) at 

org.apache.xerces.impl.dv.xs.SchemaDVFactoryImpl.<clinit>(Unknown Source) Truncated. see log file for complete stacktrace

如果您查看 org.apache.xerces.impl.xpath.regex.RegularExpression 的源代码,您会看到 RegularExpression 在 2.11.0 版本中具有以下 ctor:

(String a) 
(String b, String d) 
(String c, String f, Locale l) 
(String d, Token t, int p, boolean h, int o)

正则表达式在 2.9.1 版本中具有以下 ctor:

(String a) 
(String b, String d) 
(String c, Token t, int p, boolean h, int o) 

所以我不明白为什么两个版本都会出现异常。

我还尝试通过配置将 xerces 配置为由过滤器类加载器加载,<prefer-application-packages> <package-name>org.apache.xerces.*<package-name>但这会导致ClassCastExceptions 因为实现混淆了。

我希望有人可以帮助我在 WebLogic 10.3.6 上运行 Dozer。

问候,

最大限度

4

2 回答 2

0

该问题可以通过更改类加载顺序来解决。添加具有以下内容的文件 weblogic-application.xml:

<prefer-application-packages>
  <package-name>org.dozer.*</package-name>
  <package-name>org.apache.*</package-name>
  <package-name>antlr.*</package-name>    
</prefer-application-packages>                      
于 2014-01-09T03:39:33.217 回答
0

我遇到了类似的情况。

我还没有找到更好的方法,但是在你的 jar 文件 META-INF 中删除文件 javax.xml.parsers.DocumentBuilderFactory 可以使它工作。但可能会导致另一个问题。

于 2012-08-03T09:13:40.000 回答