由于项目的特殊需要,PHP程序从sqlserver数据库中读取和存储数据。
在实际操作过程中,常会出现乱码。一种是从SQLserver中读取的数据在页面上显示为乱码,还有一种情况是将数据存储到Sqlserver中,在数据表中是乱码。
正常情况下,出现乱码一般是编码的问题。Sqlserver数据库安装时,一般默认是GB2312编码,所以要保证php和sqlserver编码保持一致。我们介绍两种方法解决。
方法一:
php页面的编码相应的需要变为GB2312,文件保存时需要保存为GB2312编码,这样php文件中的中文字符才能正常解析。
php要输出头:
header("Content-Type: text/html; charset=gb2312")
静态页面:
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
方法二:用iconv函数将utf-8编码的页面转成gb2312
最近需要用到iconv函数把抓取来过的utf-8编码的页面转成gb2312, 发现只有用iconv函数把抓取过来的数据一转码数据就会无缘无故的少一些。 让我郁闷了好一会儿,去网上一查资料才知道这是iconv函数的一个bug。iconv在转换字符"—"到gb2312时会出错。
解决方法很简单,就是在 需要转成的编码后加 "//IGNORE" 也就是iconv函数第二个参数后,如下:
iconv("UTF-8","GB2312//IGNORE",$data)
ignore的意思是忽略转换时的错误,如果没有ignore参数,所有该字符后面的字符串都无法被保存。
声明:如需转载,请注明来源于www.webym.net并保留原文链接:http://www.webym.net/jiaocheng/393.html