INFO: couldn’t set dynamic validation SAX not featureorg.xml.sax.SAXNotRecognizedException: feature‘http://apache.org/xml/features/validation/dynamic’ recognized. ……
仔细分析一下,发现该错误的原因是WebLogic 10.3版本中的XML解析器出了问题,在
WebLogic
Server10.3
中
,
weblogic.jar
里
的
META-INF/services/javax.xml.parsers.SAXParserFactory指定了默认的SAX Parser类,即weblogic.xml.jaxp.RegistrySAXParserFactory。
反编译该类的代码发现该类继承于SAXParserFactory,但是却没有正确重写其父类的相关方法,即RegistrySAXParserFactory类中的setXInludeAware()方法本应为setXIncludeAware(),这个应该是开发人员的拼写错误,属WebLogic的BUG。
public void setXInludeAware(boolean paramBoolean)
{
this.factoryProperties.put(SAXFactoryProperties.XINCL, paramBoolean);
if (this.factory != null)
this.factory.setXIncludeAware(paramBoolean);
}
复制代码
其父类的API为佐证:
setXIncludeAware public void setXIncludeAware(boolean state) 设置 XInclude 处理的状态。
如果在文档实例中发现 XInclude 标记,则应按 XML Inclusions (XInclude) Version 1.0 中指定的方式处理。
XInclude 处理默认为 false。
参数:state – 将 XInclude 处理设置为 true 或 false 抛出: UnsupportedOperationException – 当该实现没有重写此方法时从以下版本开始:1.5
解决方案为:
编辑setDomainEnv.cmd/setDomainEnv.sh,插入
.cmd: set JAVA_OPTIONS=%JAVA_OPTIONS%
-Djavax.xml.parsers.SAXParserFactory=com.sun.org.apache.xerces.internal.jaxp.SAXParserFactoryImpl
.sh: JAVA_OPTIONS=\"${JAVA_OPTIONS}
-Djavax.xml.parsers.SAXParserFactory=com.sun.org.apache.xerces.internal.jaxp.SAXParserFactoryImpl\"
export JAVA_OPTIONS
因篇幅问题不能全部显示,请点此查看更多更全内容