javascript中中文轉碼的方法

js對文字進行編碼涉及3個函數:

escape,encodeURI,encodeURIComponent,相應3個解碼函數:unescape,decodeURI,decodeURIComponentjavascript


一、   傳遞參數時須要使用encodeURIComponent,這樣組合的url纔不會被#等特殊字符截斷。           前端

                 
例如:java

<script language="javascript">web

  document.write('<a href="http://passport.baidu.com/?logout&aid=7&u= +encodeURIComponent("http://cang.baidu.com/bruce42")+">退出</a>');面試

</script>後端


二、   進行url跳轉時能夠總體使用encodeURI安全

例如:函數

Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");編碼

 

三、   js使用數據時能夠使用escapeurl

例如:蒐藏中history紀錄。


四、   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

須要注意和強調:

中文轉碼,對於前端來講意義重大,涉及先後端交互問題。前端數據傳輸給後臺時,要作的第一件事就是把中文轉碼,這樣能夠有效地防止數據被劫持和攻擊,在必定程度上能夠有效地保證web數據安全。這也是各大公司面試常見的面試問題。

相關文章
相關標籤/搜索