/** * 浏览器友好的变量输出 * @param mixed $var 变量 * @param boolean $echo 是否输出 默认为True 如果为false 则返回输出字符串 * @param string $label 标签 默认为空 * @param boolean $strict 是否严谨 默认为true * @return void|string */function dump($var, $echo = true, $label = null, $strict = true){$label = (null === $label) ? "" : rtrim($label) . " ";if (!$strict) {if (ini_get("html_errors")) {$output = print_r($var, true);$output = "<pre>" . $label . htmlspecialchars($output, ENT_QUOTES) . "</pre>";} else {$output = $label . print_r($var, true);}} else {ob_start();var_dump($var);$output = ob_get_clean();if (!extension_loaded("xdebug")) {$output = preg_replace("/]=> (s+)/m", "] => ", $output);$output = "<pre>" . $label . htmlspecialchars($output, ENT_QUOTES) . "</pre>";}}if ($echo) {echo ($output);return null;} else {return $output;}}测试代码
$a = "中文";$a = iconv("UTF-8", "GB2312", $a);dump($a);echo "<hr />";var_dump($a);测试结果
发现仅仅var_dump有输出,而dump没有输出。
错误分析,定位htmlspecialchars
追踪调试函数,可以检测出问题出在htmlspecialchars这个函数上。
官网描述:5.4版本之前此函数的默认编码为ISO-8859-1,5.4和5.5版本默认编码为UTF-8,5.6之后则使用配置编码作为默认编码。 p>
这里PHP Version 5.6.21,那么htmlspecialchars使用的编码即为配置项的编码,如下:
htmlspecialchars使用UTF-8编码,对于gbk,gb2312等中文编码的字符串,则无输出。只要htmlspecialchars函数参数的字符串中包含一个gbk或者gb2312编码的字符,则无输出。测试如下:
$b = "中文abc";$a = iconv("UTF-8", "GB2312", $b);$c = $b.$a;var_dump(htmlspecialchars($a, ENT_QUOTES)); // 无输出var_dump(htmlspecialchars($b, ENT_QUOTES)); // 输出正常var_dump(htmlspecialchars($c, ENT_QUOTES)); // 无输出解决方案
$b = "中文abc";$a = iconv("UTF-8", "GB2312", $b);$c = $b.$a;var_dump(htmlspecialchars($a, ENT_QUOTES, "ISO-8859-1")); // 有输出,gb2312编码中文乱码var_dump(htmlspecialchars($b, ENT_QUOTES, "ISO-8859-1")); // 输出正常var_dump(htmlspecialchars($c, ENT_QUOTES, "ISO-8859-1")); // 有输出,gb2312编码中文乱码所以将Thinkphp的dump函数中htmlspecialchars函数加上默认编码ISO-8859-1即可。