ThinkPHP自动转义存储富文本编辑器内容导致读取出错的解决方法


Posted in PHP onAugust 08, 2014

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 相关文章推荐
海河写的 Discuz论坛帖子调用js的php代码
Aug 23 PHP
兼容PHP5的PHP目录管理函数库
Jul 10 PHP
精通php的十大要点(上)
Feb 04 PHP
PHP 强制下载文件代码
Oct 24 PHP
php实现查看邮件是否已被阅读的方法
Dec 03 PHP
PHP实现生成唯一会员卡号
Aug 24 PHP
CI框架简单邮件发送类实例
May 18 PHP
PHP单例模式详解及实例代码
Dec 21 PHP
php 人员权限管理(RBAC)实例(推荐)
May 24 PHP
php爬取天猫和淘宝商品数据
Feb 23 PHP
PHP使用Session实现上传进度功能详解
Aug 06 PHP
php use和include区别总结
Oct 13 PHP
PHP连接sql server 2005环境配置及问题解决
Aug 08 #PHP
getJSON跨域SyntaxError问题分析
Aug 07 #PHP
PHP+FastCGI+Nginx配置PHP运行环境
Aug 07 #PHP
PHP生成数组再传给js的方法
Aug 07 #PHP
PHP彩蛋信息介绍和阻止泄漏的方法(隐藏功能)
Aug 06 #PHP
PHP编程中的常见漏洞和代码实例
Aug 06 #PHP
Discuz7.2版的faq.php SQL注入漏洞分析
Aug 06 #PHP
You might like
利用static实现表格的颜色隔行显示的代码
2007/09/02 PHP
wordpress安装过程中遇到中文乱码的处理方法
2015/04/21 PHP
php格式化电话号码的方法
2015/04/24 PHP
再推荐十款免费的php开发工具
2015/11/09 PHP
PHP 获取指定地区的天气实例代码
2017/02/08 PHP
Laravel 6 将新增为指定队列任务设置中间件的功能
2019/08/06 PHP
PHP7 其他语言层面的修改
2021/03/09 PHP
javascritp实现input输入框相关限制用法
2007/06/29 Javascript
childNodes.length与children.length的区别
2009/05/14 Javascript
Jquery下的26个实用小技巧(jQuery tips, tricks &amp; solutions)
2010/03/01 Javascript
js将iframe中控件的值传到主页面控件中的实现方法
2013/03/11 Javascript
IE浏览器下PNG相关功能
2015/07/05 Javascript
js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)
2016/03/09 Javascript
动态加载js、css的实例代码
2016/05/26 Javascript
浅析Node.js:DNS模块的使用
2016/11/23 Javascript
详解使用Typescript开发node.js项目(简单的环境配置)
2017/10/09 Javascript
微信小程序云开发 搭建一个管理小程序
2019/05/17 Javascript
vue源码中的检测方法的实现
2019/09/26 Javascript
解决vue初始化项目时,一直卡在Project description上的问题
2019/10/31 Javascript
压缩Vue.js打包后的体积方法总结(Vue.js打包后体积过大问题)
2020/02/03 Javascript
vue路由传参的基本实现方式小结【三种方式】
2020/02/05 Javascript
详解vue3.0 diff算法的使用(超详细)
2020/07/01 Javascript
vue.js实现h5机器人聊天(测试版)
2020/07/16 Javascript
微信小程序实现滚动Tab选项卡
2020/11/16 Javascript
Python Web框架Flask中使用七牛云存储实例
2015/02/08 Python
python+selenium select下拉选择框定位处理方法
2019/08/24 Python
使用Tensorflow-GPU禁用GPU设置(CPU与GPU速度对比)
2020/06/30 Python
python GUI计算器的实现
2020/10/09 Python
html5使用window.postMessage进行跨域实现数据交互的一次实战
2021/02/24 HTML / CSS
如何现实servlet的单线程模式
2014/08/05 面试题
旅游与酒店管理的自我评价分享
2013/11/03 职场文书
精彩的广告词
2014/03/19 职场文书
农村党建工作汇报材料
2014/10/27 职场文书
岳庙导游词
2015/02/04 职场文书
党员干部廉政承诺书
2015/04/28 职场文书
zabbix agent2 监控oracle数据库的方法
2021/05/13 Oracle