mysql htmlspecialchars_htmlspecialchars输出为空的问题

这个问题是在近期发生的,感觉自从 PHP 5.3升级到了 5.6以后好多地方出错。

试验了很多办法,只要用了htmlspecialchars就会输出为空。百度了下,找到了问题的所在。

因为php5.4之后对htmlspecialchars的默认编码做出了改变,为utf-8,库中的数据以及文件都是gbk的

解决办法呢,修改所有用到htmlspecialcahrs('','','ISO-8859-1')的地方,设定编码吧,或者在头部增加ini_set('default_charset','gbk');这个,,

在或者是封装一个函数,把用到这个函数的地方都替换掉。。。

当然了 大牛的做法如下:

直接修改源码,重编译!

修改ext/standard/html.c

大概在372行

/* Default is now UTF-8 */

if (charset_hint == NULL)

return cs_utf_8;

把cs_utf_8改成 cs_8859_1

/* Default is now UTF-8 */

if (charset_hint == NULL)

return cs_8859_1;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值