从Mysql获取的汉字显示??????

司机系统服务器昨天迁移到了新的云主机上,功能但是基本上测试通过,但是通过crontab –e写的定时发送邮件的任务没有测试,于是把自己的邮箱写入到发送邮件的列表中,执行定时任务后,发现从数据库中获取的汉字全部显示为”?????“,基本判定为字符编码的问题,今天到公司添加mysql_set_charset(‘set names utf8’),保存后再进行测试,收到的邮件还是显示”??????“,然后把mysql_set_charset(‘set names utf8’)换成mysql_query(‘set names utf8’),测试还是同样的问题,然后又把utf8换成gbk,添加header("Content-type: text/html; charset=utf8"),还是未果,各种方法几乎都试过了,都没有解决。由于发邮件测试的方法十分不便,然后把发邮件改成直接浏览器显示,再进行测试,结果就发现了问题的所在:

         页面提示:

( ! ) Deprecated: mysql_set_charset(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in E:\www\localhost\drivers\server\send_mail.php on line 14

 

换成mysql_query()后,提示

( ! ) Deprecated: mysql_query(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in E:\www\localhost\drivers\server\send_mail.php on line 14

 

可以断定是这两条命令的原因,经过查询php.net发现,这两条命令已经在php5.5.0以后的版本中废弃了,相关介绍如下:

mysql_query()     http://php.net/manual/zh/function.mysql-query.php

mysql_set_charset()http://php.net/manual/zh/function.mysql-set-charset.php

 

遂使用

$connection = new PDO($config['connectionString'], $config['username'], $config['password']);
$connection->query("set names utf8");

 

重新测试,问题解决。


转载于:https://my.oschina.net/u/2437670/blog/497458

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值