300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > php读取sql数据库乱码 PHP与Sqlserver数据库出现乱码的解决办法

php读取sql数据库乱码 PHP与Sqlserver数据库出现乱码的解决办法

时间:2019-02-17 16:56:13

相关推荐

php读取sql数据库乱码 PHP与Sqlserver数据库出现乱码的解决办法

由于项目的特殊需要,PHP程序从sqlserver数据库中读取和存储数据。

在实际操作过程中,常会出现乱码。一种是从SQLserver中读取的数据在页面上显示为乱码,还有一种情况是将数据存储到Sqlserver中,在数据表中是乱码。

正常情况下,出现乱码一般是编码的问题。Sqlserver数据库安装时,一般默认是GB2312编码,所以要保证php和sqlserver编码保持一致。我们介绍两种方法解决。

方法一:

php页面的编码相应的需要变为GB2312,文件保存时需要保存为GB2312编码,这样php文件中的中文字符才能正常解析。

php要输出头:

header("Content-Type: 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参数,所有该字符后面的字符串都无法被保存。

声明:如需转载,请注明来源于并保留原文链接:/jiaocheng/393.html

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。