PHP中文乱码解决方案
汉字乱码真是一个悲催的事情,JAVA讨厌汉字,PHP也不喜欢汉字;
Java乱码最终使用了spring给出的过滤器来过滤,处处过滤,其实影响了速度,不过没有办法,汉字就是W国首先不考虑的事情;
想不到PHP也是乱码处处在,当你使用亲兄弟MySQL的时候,汉字显得那么亲切,从未考虑过他会变成天书;不过为了和其他其他交互,把PHP的手伸到SQLSERVER的时候,乱码来了,原因是第三方系统用的GBK编码;
哎,转换吧;
1,PHP自带的转换函数ICONV,一个高大上的函数;
stringiconv(string$in_charset,string$out_charset,string$str)
使用DEMO:
<?php
$text="ThisistheEurosymbol''.";
echo'Original:',$text,PHP_EOL;
echo'TRANSLIT:',iconv("UTF-8","ISO-8859-1//TRANSLIT",$text),PHP_EOL;
echo'IGNORE :',iconv("UTF-8","ISO-8859-1//IGNORE",$text),PHP_EOL;
echo'Plain :',iconv("UTF-8","ISO-8859-1",$text),PHP_EOL;
?>
大家都推荐的函数,不过使用之后无法转换,没有错误,字符也没有转换,NO!
2,另辟蹊径,还有一个大家质疑效率不高的函数,不过无论如何,先实现再考虑其他三
//检查该函数是否可用
echofunction_exists('mb_convert_encoding');
//检测当前编码
echomb_detect_encoding($val,"GBK,GB2312,UTF-8");
//转换编码,把CP936(就是GBK)转换成UTF-8
$v=mb_convert_encoding($val,"UTF-8","CP936");
结果成功了;
好吧,先用着吧,为了转换数据库查询的结果集,制作一个转换函数:
1,函数“乱码克星”:
//$fContents字符串
//$from字符串的编码
//$to要转换的编码
functionauto_charset($fContents,$from='gbk',$to='utf-8'){
$from = strtoupper($from)=='UTF8'?'utf-8':$from;
$to = strtoupper($to)=='UTF8'?'utf-8':$to;
if(strtoupper($from)===strtoupper($to)||empty($fContents)||(is_scalar($fContents)&&!is_string($fContents))){
//如果编码相同或者非字符串标量则不转换
return$fContents;
}
if(is_string($fContents)){
if(function_exists('mb_convert_encoding')){
returnmb_convert_encoding($fContents,$to,$from);
}else{
return$fContents;
}
}
elseif(is_array($fContents)){
foreach($fContentsas$key=>$val){
$_key= auto_charset($key,$from,$to);
$fContents[$_key]=auto_charset($val,$from,$to);
if($key!=$_key)
unset($fContents[$key]);
}
return$fContents;
}
else{
return$fContents;
}
}
2,使用:
//打印输出查询结果(假设你的结果)
$arr=array();
while($list=mssql_fetch_row($row))
{
$arr[]=$list;
}
$s=auto_charset($arr,'gbk','utf-8');
//打印试试,在浏览器设置编码为UFT-8,看没有乱码
print_r($s);die();
以上所述就是本文关于php中文乱码的介绍了,希望大家能够喜欢。