【ThinkPHP學習】ThinkPHP自動轉義儲存富文字編輯器內容導致讀取出錯,
RT.
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功能禁用掉,以後需要使用的時候再手動調用即可。
再次測試,這一次就解決了問題了。