默認這個方法是開啟的。也就是說,我們往數據庫里面存儲的數據中都會經過htm " /> 国产在线国偷精品免费看,成人三级毛片,亚洲国产精品一区二区尤物区

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

ThinkPHP自動轉義存儲富文本編輯器內容導致讀取出錯的解決方法

Thinkphp的conf文件中的Convention.php有一個配置選項

'DEFAULT_FILTER'        =>  'htmlspecialchars', // 默認參數過濾方法 用于I函數...
默認這個方法是開啟的。也就是說,我們往數據庫里面存儲的數據中都會經過htmlspecialchars這個函數的轉義處理。

我在我的項目中使用了Kindeditor富文本編輯器(或許你使用的是Ueditor/ckeditor),通過富文本編輯器編輯文章的內容然后存儲到數據庫中,再從數據庫中讀取顯示到網頁上來。

在這個過程中,我遇到一個問題,當我在insert方法直接顯示我將提交到數據庫里的文本數據時,能夠正常解析成HTML頁面,但是當我再從數據庫里面讀取HTML數據時,文章內容就變成了一整段HTML代碼。dump輸出我讀取到的數組內容,可以很清楚的看到是已經轉義的內容。

1.數據庫中存儲的內容以及讀取出來的文章內容實例:

<p> 你們知道嗎?</p>

2.在html頁面中解析出來的內容效果:

“<p> <span style="white-space:pre"> </span><img src="/17joys/Public/kindeditor/attached/image/20140807/20140807110915_31727.jpg" alt="" width="800" height="600"><span style="white-space:pre"> </span></p>”

很明顯可以看出,原來應該變成HTML標簽的內容現在被解析成了文本里面的內容,而且在文本內容的最外面還加上了雙引號。

正常的顯示應該是沒有雙引號的才對。數據庫讀取出來的數據就是HTML頁面的源代碼,然后插入HTML頁面之后,標簽被解釋,標簽內的內容顯示成頁面。

通過上面的分析,可以確定,是Thinkphp在內容存儲的過程中自動對內容進行了轉義處理,導致了數據庫中存儲的內容變成了轉義后的內容,再次讀出來的時候HTML會自動將原本屬于標簽的內容轉義成為正文文本。

所以,果斷到TP的conf目錄下找convention.php配置文件,將DEFAULT_FILTER功能禁用掉,以后需要使用的時候再手動調用即可。

再次測試,這一次就解決了問題了。

php技術ThinkPHP自動轉義存儲富文本編輯器內容導致讀取出錯的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 扶余县| 鲜城| 盐池县| 剑阁县| 华坪县| 黄浦区| 西城区| 玉门市| 句容市| 昌乐县| 西乌珠穆沁旗| 台安县| 米林县| 贵港市| 长葛市| 昌黎县| 饶阳县| 蒙自县| 龙南县| 乐业县| 商都县| 武鸣县| 休宁县| 襄樊市| 二手房| 深泽县| 南陵县| 石城县| 平江县| 呼伦贝尔市| 佛山市| 璧山县| 遵义市| 当阳市| 高密市| 贡嘎县| 尉氏县| 千阳县| 务川| 横峰县| 通江县|