0

我首先使用 http.get 保存一个 txt 文件:

         http.get(path: path,
           contentType: TEXT,
           query: [id:dapId, instance:alias, format:'xml', file:portalFile]) {resp, reader ->

           println "response status: ${resp.statusLine}"  
         println 'Headers: -----------'  
       resp.headers.each { h ->     
            println " ${h.name} : ${h.value}"  
       }

       new File(outputFileName).withWriter{out -> out << reader}
        }

然后在 XmlSlurper().parse 中的 outputFileName 中使用新创建的文件,如下所示:

    def inputFile = new File(outputFileName)
      def domain = new XmlSlurper().parse(inputFile) 

但是在执行 new XmlSlurper().parse(inputFile) 时出现错误:

Caught: org.xml.sax.SAXParseException: White spaces are required between publicId and systemId.

我注意到使用 http.get 创建的文本文件 outputFileName 似乎是 HTML 文件而不是 XML 文件。所以我将它应该包含的 XML 代码复制并粘贴到 outputFileName 中,跳过了代码的第一部分,只运行了 XmlSlurper().parse() 位并且它工作。

outputFileName 应该是一个 xml 文件吗?它有很多 HTML 标签。

提前致谢!:D

4

1 回答 1

1

HTML != XML。您的 HTML 文件可能不是有效的 XML。因此,XML 解析器在解析过程中失败。您确定从 http GET 创建的文件是有效的 XML 文件吗?

于 2011-08-30T20:48:15.237 回答