您的当前位置:首页正文

解决org.xml.sax.SAXNotRecognizedException异常

来源:九壹网
近日,在项目的实施过程中遇到了以下问题:

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

因篇幅问题不能全部显示,请点此查看更多更全内容

Top