最近遇到一個問題,數(shù)據(jù)中包含中文引號,結(jié)果被轉(zhuǎn)義存儲到數(shù)據(jù)庫,取數(shù)據(jù)的時候用了htmlspecialchars_decode把實體轉(zhuǎn)義回去,結(jié)果發(fā)現(xiàn)并沒有生效,看了一下htmlspecialchars_decode只支持5個指定的實體轉(zhuǎn)換,其他的[我遇到的是中文引號ldrquo;]
因此發(fā)現(xiàn)了html_entity_decode可以把所有的實體轉(zhuǎn)義回去~
另外,如果你在瀏覽器中測試,會發(fā)現(xiàn)是轉(zhuǎn)義回去的,這是因為瀏覽器自動給處理了。實際上是沒有轉(zhuǎn)回去的,可以到命令行試試哦~~
html_entity_decode:把所有的html實體轉(zhuǎn)換為原來的字符
與htmlentities() 相反
更準(zhǔn)確地說,這個函數(shù)解碼所有的實體(包括所有的數(shù)字實體):a)對于所選擇的文檔類型必須是有效的 - 即對于XML,這個函數(shù)不解碼可能在某些DTD中定義的命名實體 - 以及b) 其中的字符或字符位于與所選編碼相關(guān)聯(lián)的編碼字符集中并且在所選文檔類型中被允許。 所有其他實體保持原樣。
htmlspecialchars_decode:將特殊的 HTML 實體轉(zhuǎn)換回普通字符
此函數(shù)的作用和 htmlspecialchars() 剛好相反。它將特殊的HTML實體轉(zhuǎn)換回普通字符。
被轉(zhuǎn)換的實體有: , " (沒有設(shè)置ENT_NOQUOTES 時), ' (設(shè)置了 ENT_QUOTES 時), 以及>。
所以并不能把不包含在以上5個的其他轉(zhuǎn)換回去。
實例
把 HTML 實體轉(zhuǎn)換為字符:
?php
$str = "lt;copy; W3CSccedil;hdeg;deg;brvbar;sect;gt;";
echo html_entity_decode($str);
?>
上面代碼的 HTML 輸出如下(查看源代碼):
!DOCTYPE html>
html>
body>
© W3CSçh°°¦§>
/body>
/html>
上面代碼的瀏覽器輸出如下:
© W3CSçh°°¦§>
您可能感興趣的文章:- IdentityServer4 QuckStart 授權(quán)與自定義Claims的問題
- IdentityServer4實現(xiàn).Net Core API接口權(quán)限認(rèn)證(快速入門)
- JPA中EntityListeners注解的使用詳解
- EF(EntityFramework) 插入或更新數(shù)據(jù)報錯的解決方法
- 詳解ASP.NET中Identity的身份驗證代碼
- c# 使用Entity Framework操作Access數(shù)據(jù)庫的示例
- Idea自動生成Entity實現(xiàn)過程詳解