• 【ThinkPHP学习】ThinkPHP自己主动转义存储富文本编辑器内容导致读取出错


    RT.

    ThinkPHP的conf文件里的Convention.php有一个配置选项

    'DEFAULT_FILTER'        =>  'htmlspecialchars', // 默认參数过滤方法 用于I函数...
    默认这种方法是开启的。也就是说,我们往数据库里面存储的数据中都会经过htmlspecialchars这个函数的转义处理。

    我在我的项目中使用了Kindeditor富文本编辑器(也许你使用的是Ueditorckeditor),通过富文本编辑器编辑文章的内容然后存储到数据库中,再从数据库中读取显示到网页上来。

    在这个过程中,我遇到一个问题,当我在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功能禁用掉,以后须要使用的时候再手动调用就可以。

    再次測试,这一次就攻克了问题了。


  • 相关阅读:
    Android之JSON格式数据解析
    SSH面试题锦集
    Mysql
    (二)Java基础巩固
    (一)Java基础巩固
    (五)Oracle函数 序列 约束 索引
    让css初学者抓狂的属性float
    微信小程序(4)--二维码窗口
    微信小程序(3)--页面跳转和提示框
    微信小程序(2)--下拉刷新和上拉加载更多
  • 原文地址:https://www.cnblogs.com/blfshiye/p/4067263.html
Copyright © 2020-2023  润新知