您好,登錄后才能下訂單哦!
這篇文章主要介紹“thinkphp不過濾html標簽如何解決”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“thinkphp不過濾html標簽如何解決”文章能幫助大家解決問題。
thinkphp不過濾html標簽的解決辦法:1、打開相應的tp文件;2、通過“strip_tags(htmlspecialchars_decode($data['post']['post_content']));”方法對已經轉換的實體進行反轉即可。
TP5 使用strip_tags過濾html標簽不起作用的解決方法
在ThinkPHP5中使用strip_tags過濾html標簽不起作用的解決辦法
在文章保存過程中需要獲取前端由Uediter編輯器編輯的html內容中的文本,基本思路是使用PHP自帶函數strip_tags()直接過濾
于是直接編輯如下:
$data = $this->request->param();
$data['post']['content'] = strip_tags($data['post']['post_content']);
echo $data['post']['post_content'];
echo $data['post']['content'];
輸出內容如下,strip_tags()函數并沒有起到作用:
<p>RWERWERWhgj<strong>ghhfhgn</strong>bfghgh</p>
<p>RWERWERWhgj<strong>ghhfhgn</strong>bfghgh</p>
查看TP5手冊-輸入變量章節-變量過濾我們可以發現,TP5默認對前端傳過來的字符串使用了htmlspecialchars轉換為 HTML 實體,因此,我的解決辦法是對已經轉換的實體進行反轉,使用htmlspecialchars_decode()函數即可以實現:
$data = $this->request->param();
$data['post']['content'] = strip_tags(htmlspecialchars_decode($data['post']['post_content']));
echo $data['post']['post_content'];
echo $data['post']['content'];
輸出如下,轉換成功:
<p>RWERWERWhgj<strong>ghhfhgn</strong>bfghgh</p>
RWERWERWhgjghhfhgnbfghgh
關于“thinkphp不過濾html標簽如何解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。