Java解析xml文件遇到特殊符號(hào)異常的情況(處理方案)
在一次Java解析xml文件的開(kāi)發(fā)過(guò)程中,使用SAX解析時(shí),出現(xiàn)了這樣一個(gè)異常信息:
Error on line 60 of document : 對(duì)實(shí)體 'xxx' 的引用必須以 ’;’ 分隔符結(jié)尾;
我打開(kāi)xml文件后,發(fā)現(xiàn)該“xxx'符號(hào)之前跟著一個(gè)”&“符號(hào),后來(lái)了解到,這類符號(hào)在xml里屬于一種特殊符號(hào),而特殊符號(hào)若沒(méi)用轉(zhuǎn)義符表示,直接用到xml文件里,就會(huì)在使用SAX等方式做解析時(shí)出現(xiàn)奇怪的異常。
其實(shí),這都是因?yàn)檫@些特殊字符造成的。
XML當(dāng)中特殊符號(hào)包括< > & ’ '等,它們是不允許作為xml文件的PCDATA,若想使用話,需用轉(zhuǎn)義符代替:
< <> >& &" '' ’
那么,若要正常讀取xml文件數(shù)據(jù),應(yīng)該如何使用轉(zhuǎn)義符替換呢?
剛開(kāi)始是想百度一番如何解決,卻發(fā)現(xiàn)好多帖子都是好幾年前的,且都沒(méi)有寫清楚怎么個(gè)解決方法,大多都是提到是特殊符號(hào)引起的解析異常,但怎么過(guò)濾掉,顯得含糊其辭,因此,只能自己胡亂搗鼓一番,搗鼓出一個(gè)比較合適的將特殊字符過(guò)濾的方案。
實(shí)現(xiàn)思路其實(shí)很簡(jiǎn)單,我們可以在讀取xml文件使用SAX解析前,先把xml文件通過(guò)Reader讀取,然后按行讀取出來(lái)拼接成一個(gè)String字符串,再使用字符串的替換方法replaceAll()將特殊符號(hào)進(jìn)行替換,替換后,就可以將字符串形式的xml直接轉(zhuǎn)成Document對(duì)象做xml解析了:
String xmlStr=s.replaceAll('&','&');
轉(zhuǎn)換方法代碼如下:
StringBuffer buffer = new StringBuffer(); BufferedReader bf= new BufferedReader(new FileReader('D:測(cè)試.xml')); String s = null; while((s = bf.readLine())!=null){ buffer.append(s.trim()); } String str = buffer.toString(); //在這一步進(jìn)行字符替換,替換成合法轉(zhuǎn)義字符 String xml=str.replaceAll('&','&'); //這里就可以將處理過(guò)的xml文件進(jìn)行讀取解析了 Document document = DocumentHelper.parseText(xml);
至此,就可以解決Java解析xml文件遇到特殊符號(hào)&出現(xiàn)異常的問(wèn)題了。
以上就是Java解析xml文件遇到特殊符號(hào)異常的情況(處理方案)的詳細(xì)內(nèi)容,更多關(guān)于Java解析xml文件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. JSP+Servlet實(shí)現(xiàn)文件上傳到服務(wù)器功能2. CSS可以做的幾個(gè)令你嘆為觀止的實(shí)例分享3. Xml簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理4. jsp實(shí)現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫(kù)的方法5. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法6. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案7. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁(yè)8. jsp文件下載功能實(shí)現(xiàn)代碼9. JSP之表單提交get和post的區(qū)別詳解及實(shí)例10. jsp+servlet實(shí)現(xiàn)猜數(shù)字游戲
