php5.4后htmlspecialchars输出为空的问题

从旧版升级到php5.4,恐怕最麻烦的就是htmlspecialchars这个问题了!当然,htmlentities也会受影响,不过,对于中文站来说一般用htmlspecialchars比较常见,htmlentities非常少用到。

可能老外认为网页普遍应该是utf-8编码的,于是苦了那些用GB2312,GBK编码的中文站......!

具体表现:

$str = "9enjoy.com的php版本是5.2.10";
echo htmlspecialchars($str);

gbk字符集下输出为空...utf-8下,输出正常。

为什么呢,原因在于5.4.0对这个函数的变化:

5.4.0   The default value for the encoding parameter was changed to UTF-8.

原来是什么呢?

string htmlspecialchars ( string $string [, int $flags = ENT_COMPAT | ENT_HTML401 [, string $encoding = ‘UTF-8‘ [, bool $double_encode = true ]]] )

Defines encoding used in conversion. If omitted, the default value for this argument is ISO-8859-1 in versions of PHP prior to 5.4.0, and UTF-8 from PHP 5.4.0 onwards.

原来是ISO-8859-1,5.4后默认变成utf-8!然后中文使用这个函数就输出为空白了。

国内一堆开源程序在5.4下都会有这样的问题,DISCUZ官方也建议用户不要升级到5.4。

解决方案:
1.苦逼的修改所有用到htmlspecialchars地方的程序

1.1 其第二个$flags参数,默认是ENT_COMPAT,因此改成
htmlspecialchars($str,ENT_COMPAT,‘GB2312‘);
为什么不是GBK?因为没有GBK这个参数,如果强行使用GBK,则报错给你看:
Warning: htmlspecialchars(): charset `gbk‘ not supported, assuming utf-8
为了能使用GBK,则改成:
htmlspecialchars($str,ENT_COMPAT,‘ISO-8859-1‘);

1.2.一样是改程序,但可以省略一个参数。
可以在网页头部加
ini_set(‘default_charset‘,‘gbk‘);
然后改成
htmlspecialchars($str,ENT_COMPAT,‘‘);
文 档中有写:An empty string activates detection from script encoding (Zend multibyte), default_charset and current locale (see nl_langinfo() and setlocale()), in this order. Not recommended.
大概意思就是:传入空字符串则使用default_charset的编码

1.3.封装一个函数吧...本来htmlspecialchars这个单词一直不好记。
function htmlout($str) {
    return htmlspecialchars($str,ENT_COMPAT,‘ISO-8859-1‘);
}
然后去批量替换。

2.直接修改源码,重编译!这也是目前我在线上做的方案。
修改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;
编译后,原程序就不用做任何调整了。
安装方法可参考:http://www.9enjoy.com/linux-upgrade-php54/

windows下怎么办?这个,自己想办法编译吧,难度比较大...
提供一个网址供参考:http://www.phpvim.net/web/php/build-php5-4-and-xdebug-on-win32.html
引用其一句话:准备好咖啡、可乐,做好准备,可能要折腾数小时…

时间: 2024-07-30 21:13:33

php5.4后htmlspecialchars输出为空的问题的相关文章

htmlspecialchars输出为空的问题

这个问题是在近期发生的,感觉自从 PHP 5.3升级到了 5.6以后好多地方出错. 试验了很多办法,只要用了htmlspecialchars就会输出为空.百度了下,找到了问题的所在. 因为php5.4之后对htmlspecialchars的默认编码做出了改变,为utf-8,库中的数据以及文件都是gbk的 解决办法呢,修改所有用到htmlspecialcahrs('','','ISO-8859-1')的地方,设定编码吧,或者在头部增加ini_set('default_charset','gbk')

26、输入一个链表,反转链表后,输出链表的所有元素。

输入一个链表,反转链表后,输出链表的所有元素. 思路:  ListNode next = null;//用来保存待反序的第一个节点(head 和 next节点) ListNode pre = null;//用来保存已经反序的第一个结点 next = head.next;//首先记录当前节点的下一个节点,(保存起来) //先用next保存head的下一个节点的信息,保证单链表不会因为失去head节点的原next节点而就此断裂 head.next = pre;//让当前节点指向前一个节点,因为要反序

Python练习题8(替换相同的字符串并输出):输入两个字母串,将两个字母串都包含的字母用'_'替换后,输出两个字母串的剩余部分 (不能为空串,区别大小写,只能包含字母)

方法一:检查输入是否为空串,循环字母串,相同的则替换,然后再用replace()方法去除,输出想要的结果 1 def str_replace(messages1,messages2): 2 if messages1.strip() == '' or messages2.strip() == '' : #检验输入不能为空串 3 tips = "输入字母串有空串,不合法" 4 return tips 5 6 if not messages1.encode('UTF-8').strip().

N15_反转链表后,输出新链表的表头。

题目描述 输入一个链表,反转链表后,输出新链表的表头. package new_offer; /** * 输入一个链表,反转链表后,输出新链表的表头. * @author Sonya *思路:遍历头插法. */ public class N15_ReverseList { public ListNode ReverseList(ListNode head) { if(head==null)return null; if(head.next==null)return head; ListNode

PAT树_层序遍历叶节点、中序建树后序输出、AVL树的根、二叉树路径存在性判定、奇妙的完全二叉搜索树、最小堆路径、文件路由

<pre class="code"><span style="font-family: %value; font-size: 14px;">03-树1. List Leaves (25) Given a tree, you are supposed to list all the leaves in the order of top down, and left to right. Input Specification: Each inpu

二叉树的创建,先中后序输出,计算叶子结点数目

#include <stdio.h> #include <iostream> #include <algorithm> using namespace std; typedef struct BiTNode { char data; struct BiTNode *l; struct BiTNode *r; } BiTNode,*BiTree; void CreatBiTree(BiTree &T) { ///按先序次序输入二叉树中结点的值(一个字符),创建二叉

php5.0后的新特性

一.PHP5.3 1.支持命名空间 2.增加goto语句 public function testStop() { goto aaa; echo 1; aaa: echo 2; } 3.新增两个魔术方法__callStatic() 调用不存在的或者是私有的静态方法时启用,当尝试以调用函数的方式调用一个对象时,__invoke() 方法会被自动调用. public function __invoke() { // TODO: Implement __invoke() method. echo 22

[剑指offer] 重建二叉树,根据前中,输出后,根据中后,输出前

参考:<剑指offer>纪念版 情况1.:给出树的前序序列和中序序列,输出后序序列 情况2 :给出树的后序序列和中序序列,输出前序序列 解决方法:根据所给出的两个序列,构造出(重建)二叉树,然后按要求再遍历输出. 重建二叉树主要利用了递归的思想,最重要的是找出序列的范围(函数传参),这个要非常仔细,很容易出错.一定要在纸上画出图,然后根据图来确定范围. 用到的两个函数: 以情况1为例: 主要用到了两个函数: BinaryTreeNode* Construct(char* preorder, c

python reload(sys) 后无法输出

重新加载sys后,在idle里无法输出内容.出现这种情况,需要将sys的三个变量重新定义. 在重新载入sys之前,为三个变量赋值 a,b,c = sys.studin,sys.studout,sys.studerr 然后重新载入sys reload(sys) 在为sys的三个变量赋值 sys.studin,sys.studout,sys.studerr = a,b,c 这样就解决了...