DOM解析XML報錯Content is not allowed in prolog解決方案詳解
報錯內(nèi)容為:
Content is not allowed in prolog. Nested exception: Content is not allowed in prolog
網(wǎng)上所述總結來說就是解析內(nèi)容內(nèi)包含BOM。這個標記是看不到的,流里面有這個標記而已。
BOM:Byte Order Mark,中文名字節(jié)順序標記。UCS規(guī)范建議在傳輸字節(jié)流前,先傳輸BOM來判斷字節(jié)順序。
其實UTF-8是不需要用BOM來表明字節(jié)順序的,但是可以 用BOM來表明編碼方式。BOM的UTF-8編碼是EF BB BF,所以呢,如果接受者收到EF BB BF開頭的字節(jié)流,就說明它是UTF-8編碼了。
解決辦法:
如果解析的是文件:
可以用UltraEdit或者EmEditor打開XML,然后另存為,保存的時候有選項是以無BOM的UTF-8保存還是以有BOM的UTF-8保存。
如果是從遠程請求回來的內(nèi)容:
那么你把返回的流New為字符串,是看不到BOM的,但是你必須截取你需要的內(nèi)容:
if(null != result && !"".equals(result)){
if(result.indexOf("<") != -1 && result.lastIndexOf(">") != -1 && result.lastIndexOf(">") > result.indexOf("<"))
result = result.substring(result.indexOf("<"), result.lastIndexOf(">") + 1);
}
也有說是DOM4J版本較低引起的,但是我看了一下我是用的版本是1.6.1,所以排除此類可能,但是在實際中我還是建議使用最新穩(wěn)定版本來進行開發(fā)。
更新
今天看日志,發(fā)現(xiàn)我的異常不是因為BOM頭引起的,幸好我也打印了收到的內(nèi)容,我一看,我去,服務器在自己處理失敗以后直接返回個 error字符串,mian了一下,果然出錯,這坑爹的玩兒。
public static void main(String[] args) throws DocumentException {
String str = "error";
Document doc = DocumentHelper.parseText(str);
System.out.println(doc.asXML());
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
實例解析觀察者模式及其在Java設計模式開發(fā)中的運用
觀察者模式定義了一種一對多的依賴關系,讓多個觀察者對象同時監(jiān)聽某一個主題對象,這個主題對象在狀態(tài)上發(fā)生變化時,會通知所有觀察者對象,使它們能夠自動更新自己.下面就以實例解析觀察者模式及其在Java設計模式開發(fā)中的運用2016-05-05
SpringBoot自定義maven-plugin插件整合asm代碼插樁
本文主要介紹了SpringBoot自定義maven-plugin插件整合asm代碼插樁,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02
SpringCloud添加客戶端Eureka Client過程解析
這篇文章主要介紹了SpringCloud添加客戶端Eureka Client過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03
SpringBoot使用CommandLineRunner接口完成資源初始化方式
這篇文章主要介紹了SpringBoot使用CommandLineRunner接口完成資源初始化方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02

