Java:如何防止EntityResolver中的’systemId’#resolveEntity(String publicId,String systemId)从绝对化到当前工作目录

前端之家收集整理的这篇文章主要介绍了Java:如何防止EntityResolver中的’systemId’#resolveEntity(String publicId,String systemId)从绝对化到当前工作目录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想解析以下 XML文档来解析其中的所有实体:
<!DOCTYPE doc SYSTEM 'mydoc.dtd'>
 <doc>&title;</doc>

我的EntityResolver应该从数据库获取具有给定系统ID的外部实体,然后执行解决方案,请参阅下面的插图:

private static class MyEntityResolver
 {
    public InputSource resolveEntity(String publicId,String systemId)
        throws SAXException,IOException
    {
        // At this point,systemId is always absolutized to the current working directory,// even though the XML document specified it as relative.
        // E.g. "file:///H:/mydoc.dtd" instead of just "mydoc.dtd"
        // Why???  How can I prevent this???

        SgmlEntity entity = findEntityFromDatabase(systemId);
        InputSource is = new InputSource(new ByteArrayInputStream(entity.getContents()));
        is.setPublicId(publicId);
        is.setSystemId(systemId);
        return is;
    }
 }

我尝试使用DOM(DocumentBuilder)和SAX(XMLReader),将实体解析器设置为MyEntityResolver(即setEntityResolver(new MyEntityResolver())),但MyEntityResolver中的systemId #resolveEntity(String publicId,String systemId)始终被绝对化为当前的工作目录.

我也尝试过调用setFeature(“http://xml.org/sax/features/resolve-dtd-uris”,false);但这对任何事都没有帮助.

那么我怎样才能达到我的目的呢?

谢谢!

解决方法

显然,还有另一个名为 EntityResolver2的界面,它是旧 EntityResolver的扩展.(谈论令人困惑的名字!)

无论如何,我发现EntityResolver2实现了我想要的,也就是说,它不会对systemId进行任何更改,因此它将始终完全是XML文档中指定的内容.

原文链接:https://www.f2er.com/java/129295.html

猜你在找的Java相关文章