最近在一个项目开发中,使用javax.xml.xpath.XPath类的evaluate计算xml节点路径,开发过程一直很顺利,直到部署上线后,才发现在生产环境中程序一直报错。在调试跟踪后,发现是Websphere服务器的某些jar包与项目中的jar包发生冲突造成的,这个问题在开发环境是不会出现的,因为开发环境用的是tomcat。问题代码如下:
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathFactory;
XPath xpath = XPathFactory.newInstance().newXPath();
String findPath = "/" + rootName + "/" + inodeName;
//updXmlDoc是org.w3c.dom.Document类型的对象
//在这里会发生异常
Node node = (Node) xpath.evaluate(findPath, updXmlDoc.getDocumentElement(),
XPathConstants.NODE);
解决办法是使用dom4j的类库去完成xpath路径检索,而不采用javax的xml类库。
//先将updXmlDoc对象转换为dom4j的Document对象
org.dom4j.Document dom4jUpdDoc=XmlDataUtils.convertDom4jDoc(updXmlDoc);
java.util.List nodes=dom4jUpdDoc.selectNodes(findPath);
以上问题暂时只发现在Websphere中存在,通过这次的修复,以后不再轻易相信“兼容所有J2EE标准的Web容器”这些话了,没有通过大规模测试验证的产品,是不可能做到的。