【ThinkPHP學習】ThinkPHP本身主動轉義存儲富文本編輯器內容致使讀取出錯

RT.php

ThinkPHP的conf文件裏的Convention.php有一個配置選項html

'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會本身主動將本來屬於標籤的內容轉義成爲正文文本。spa

因此,果斷到TP的conf文件夾下找convention.php配置文件,將DEFAULT_FILTER功能禁用掉,之後需要使用的時候再手動調用就能夠。code

再次測試,這一次就攻克了問題了。htm

相關文章
相關標籤/搜索