在開發中遇到javascript從後臺獲取的url 會被轉義,如:http://localhost:8080/Home/Index?a=14&b=15&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, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'");; 9 }, 10 /** 11 * @function unescapeHTML 還原html腳本 < > & " ' 12 * @param a - 13 * 字符串 14 */ 15 unescapeHTML: function(a){ 16 a = "" + a; 17 return a.replace(/</g, "<").replace(/>/g, ">").replace(/&/g, "&").replace(/"/g, '"').replace(/'/g, "'"); 18 },
1,escapeHTML將< > & " '轉成字符實體
使用場景:
(1)用戶在頁面中錄入(好比輸入框) <script>alert(2);</script>, js將該內容提交給後端保存
(2)顯示時,後端將字符串返回前端;js接收到以後:
a, 使用escapeHTML,將字符串轉爲 <script>alert(2);</script>此時,瀏覽器將能正確解析,由於瀏覽器接收到實體字符後,轉成對應的尖括號等。
b, 不使用escapeHTML,瀏覽器一看到<,便認爲是html標籤的開始,直接把剛纔的字符串當腳本執行了,這就是xss漏洞。
2,unescapeHTML將字符實體轉成< > & " '
使用場景:
後端將已經轉義後的內容顯示到頁面;好比<script>alert(2);</script>
js收到後:
a,前端進行unescapeHTML,則能夠直接dom操做,將標籤顯示到頁面。
b,前端沒有unescapeHTML,則原樣輸出<script>alert(2);</script>,但此時並無執行。
轉義字符:
後端
提示:使用實體名而不是數字的好處是,名稱易於記憶。不過壞處是,瀏覽器也許並不支持全部實體名稱(對實體數字的支持卻很好)。瀏覽器