1. 程式人生 > >thinkphp的dump函式無輸出

thinkphp的dump函式無輸出

Thinkphp的dump函式

/**
 * 瀏覽器友好的變數輸出
 * @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('/\]\=\>\n(\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之後則使用配置編碼作為預設編碼。
這裡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即可。