[epub] epub.js的ePubReader函數報URI malformed錯誤的解決辦法


報錯信息:URI malformed

今天遇到了一個奇怪的問題折騰三個小時,最后發現是作者在底層使用了decodeURIComponent進行URL解碼,而我在應用層使用了escape/unescape進行編碼和解碼,才造成了此錯誤。

仔細讀了依賴的reader.min.js源碼發現:ePubReader函數接受URI並解析epub文件時,需要在URI尾部使用#對章節進行定位,因此使用了decodeURIComponent進行解碼。

解決方案:將構造URI的方法使用encodeURIComponent和decodeURIComponent進行編碼解碼傳輸。不能使用escape和unescape。

參考資料:https://www.cnblogs.com/jhxk/articles/1634359.html

JavaScript對文字進行編碼涉及3個函數:escape,encodeURI,encodeURIComponent,相應3個解碼函數:unescape,decodeURI,decodeURIComponent 1、 傳遞參數時需要使用encodeURIComponent,這樣組合的url才不會被#等特殊字符截斷。 例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u='+encodeURIComponent ("http://cang.baidu.com/bruce42")+'">退出</a>');</script>

2、 進行url跳轉時可以整體使用encodeURI 例如:Location.href=encodeURI(http://cang.baidu.com/do/s?word=百度&ct=21);

3、 js使用數據時可以使用escape 例如:搜藏中history紀錄。 4、   escape對0-255以外的unicode值進行編碼時輸出%u****格式,其它情況下escape,encodeURI,encodeURIComponent編碼結果相同。 最多使用的應為encodeURIComponent,它是將中文、韓文等特殊字符轉換成utf-8格式的url編碼,所以如果給后台傳遞參數需要使用encodeURIComponent時需要后台解碼對utf-8支持(form中的編碼方式和當前頁面編碼方式相同) escape不編碼字符有69個:*,+,-,.,/,@,_,0-9,a-z,A-Z encodeURI不編碼字符有82個:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
 encodeURIComponent不編碼字符有71個:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM