【轉義字符】HTML 字符實體< >: &等

在開發中遇到javascript從後臺獲取的url 會被轉義,如:http://localhost:8080/Home/Index?a=14&amp;b=15&amp;c=123,想把它轉成http://localhost:8080/Home/Index?a=14&b=15&c=123javascript

網上找了半天的解決方案:html

轉義分爲escapeHTML和unescapeHTML,先看兩個函數的實現。前端

js代碼:java

 1 /**
 2  * @function escapeHTML 轉義html腳本 < > & " '
 3  * @param a -
 4  *            字符串
 5  */
 6 escapeHTML: function(a){
 7     a = "" + a;
 8     return a.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&apos;");;
 9 },
10 /**
11  * @function unescapeHTML 還原html腳本 < > & " '
12  * @param a -
13  *            字符串
14  */
15 unescapeHTML: function(a){
16     a = "" + a;
17     return a.replace(/&lt;/g, "<").replace(/&gt;/g, ">").replace(/&amp;/g, "&").replace(/&quot;/g, '"').replace(/&apos;/g, "'");
18 },

1,escapeHTML將< > & " '轉成字符實體 
使用場景: 
(1)用戶在頁面中錄入(好比輸入框) <script>alert(2);</script>, js將該內容提交給後端保存 
(2)顯示時,後端將字符串返回前端;js接收到以後: 
a, 使用escapeHTML,將字符串轉爲 &lt;script&gt;alert(2);&lt;/script&gt;此時,瀏覽器將能正確解析,由於瀏覽器接收到實體字符後,轉成對應的尖括號等。 
b, 不使用escapeHTML,瀏覽器一看到<,便認爲是html標籤的開始,直接把剛纔的字符串當腳本執行了,這就是xss漏洞。 

2,unescapeHTML將字符實體轉成< > & " ' 
使用場景: 
後端將已經轉義後的內容顯示到頁面;好比&lt;script&gt;alert(2);&lt;/script&gt; 
js收到後: 
a,前端進行unescapeHTML,則能夠直接dom操做,將標籤顯示到頁面。 
b,前端沒有unescapeHTML,則原樣輸出<script>alert(2);</script>,但此時並無執行。 

轉義字符: 

caefd511-7ae6-3a26-889a-1c741607510e.jpg (436×454)

後端

提示:使用實體名而不是數字的好處是,名稱易於記憶。不過壞處是,瀏覽器也許並不支持全部實體名稱(對實體數字的支持卻很好)。瀏覽器

相關文章
相關標籤/搜索