轉自:http://blog.csdn.net/hj7jay/article/details/51280405
眾所周知頁面上的字符內容通常都需要進行HTML轉義才能正確顯示,尤其對於Input,Textarea提交的內容,更是要進行轉義以防止javascript注入攻擊。
通常的HTML轉義主要是針對內容中的"<",">","&",以及空格、單雙引號等。但其實還有很多字符也需要進行轉義。具體的可以參考
這篇文章。
** 1、HTML轉義
參考上面的提到的文章,基本上可以確定以下的轉義的范圍和方式。
1)對"\""、"&"、"'"、"<"、">"、空格(0x20)、0x00到0x20、0x7F-0xFF
以及0x0100-0x2700的字符進行轉義,基本上就覆蓋的比較全面了。
用javascript的正則表達式可以寫為:
this.REGX_HTML_ENCODE = /"|&|'|<|>|[\x00-\x20]|[\x7F-\xFF]|[\u0100-\u2700]/g;
2)為保證轉義結果對瀏覽器的無差別,轉義編碼為實體編號,而不用實體名稱。
3)空格(0x20)通常轉義為“ ”也就是“ ”。
轉義的代碼非常簡單:
** 2、反轉義
既然有轉義,自然需要反轉義。
1) 對“&#num;”實體編號的轉義,直接提取編號然后fromCharCode就可以得到字符。
2) 對於諸如“<”,需要建立一張如下的表來查詢。
this.HTML_DECODE = {
"<" : "<",
">" : ">",
"&" : "&",
" ": " ",
""": "\"",
"©": "©"
// Add more
};
由此我們可以有反轉義的正則表達式:
this.REGX_HTML_DECODE = /&\w+;|&#(\d+);/g;
反轉的代碼也很簡單,如下:
** 3、一個有意思的認識
其實在用正則表達式轉義之前,我一直都是用遍歷整個字符串,逐個比較字符的方式。直到有一天,看到一篇文章說,javascript正則表達式是C實現的,比自己用javascript遍歷字符要快,於是我就試着改寫成上面這種方式。雖然代碼看起來的確顯得神秘而又牛叉,但遺憾的是,在我的Chrome 11 (FreeBSD 64 9.0)上,遍歷字符轉義/反轉的方式要比上面正則表達式的代碼快2到3倍(字符串長度越長越明顯)。其實,想想也能明白為什么。
** 4、完整版本的代碼
在實際的使用中可以有兩種方式:
1)使用js.lang.String.encodeHtml(s)和js.lang.String.decodeHtml(s)。
2)還可以直接擴展String的prototype
