网站部署时出个小bug

在我把网战代码上传的服务器之后出现了部分乱码问题。

在后台用富文本编辑器编辑文章保存之后,显示出的文章会在部分引号前多出一条反斜线\。

检查一下网页源码

网站部署时出个小bug_第1张图片

丫的,哪来的这么多反斜线,后来测试一下我知道了,最开始是因为双引号"导致出了一个反斜线作转义,由于我保存修改多次,保存一次反斜线数量翻一倍,然后就成了这个样子了。

这不仅仅导致双引号显示时多出反斜杠,更要命的是插入文章的图片也不能显示了,因为图片路径里也多次一些反斜杠。

但是在我本地开发环境测试时这个双引号什么的根本就不会引发转义啊!检查了一下环境配置,我用的是万网6块钱买的一个虚拟主机,环境都是万网配好的,开始我并没有在意,看了一下PHP版本是5.3,而我本地用的是PHP5.5,难道是因为这个?还好万网提供了几个不同的PHP版本可以选择,我把PHP版本调成5.5以后果然问题就解决了。

还好只是PHP版本问题,我开始担心是数据库问题,因为只是个虚拟主机,我没办法去修改数据库设置的。


那么问题来了

数据流向,大概是从前端一个textarea到ajax到后台php,htmlspecialchars函数处理后再到数据库,取数据给htmlspecialchars_decode函数处理,再到前端显示。究竟是在哪个环节出了问题?

由于是PHP版本问题导致的,我最先想到的是htmlspecialchars或者是htmlspecialchars_decode函数因为版本不同出的问题。远程连接数据库,直接查看数据库里的内容,发现已经出现问题了。那么问题就出在存入数据库之前。

查了一下htmlspecialchars函数,函数原型:

string htmlspecialchars( string $string [,int $flags = ENT_COMPAT | ENT_HTML401 [,string $encoding = ini_get("default_charset") [,bool $double_encode = true]]] )

看一下更新日志

网站部署时出个小bug_第2张图片

5.4之后encoding参数默认值改成了UTF-8,网上搜了一下,有人说这个问题http://www.9enjoy.com/php54-htmlspecialchars/,不过这个是导致中文变空白,我这个反斜线又是怎么回事?算了,看也看不明白,写个demo试一下。

就一个表单post方式提交一个textarea到php,先输出$_POST看一眼,然后我就发现在$_POST里就出问题了,5.3和更低版本(也就试了5.2)英文格式的单引号和双引号前面出现了转义符反斜线\,当然如果输入内容有反斜线也会多出一个反斜线,5.4及以上版本不会出现问题。

网站部署时出个小bug_第3张图片

然后我也试了下htmlspecialchars和htmlspecialchars_decode,发现反斜线并没变多,也就说它俩没有问题。那问题就出在$_POST上了。查一下$_POST的更新日志

网站部署时出个小bug_第4张图片

仅此一句,好吧,那先这样吧。换get方式提交,结果和post一样出问题,也同样换到5.4以上版本问题就没有了。这个水就有点深了,我先洗洗睡了。


一个偶然的机会,才知道PHP有魔术引号一说,不过魔术引号在5.4版本被移除了,上面出现的问题正是魔术引号引发的。

网站部署时出个小bug_第5张图片

你可能感兴趣的:(网站部署时出个小bug)