Heim  >  Artikel  >  Backend-Entwicklung  >  PHP发送移动MAS短信乱码的解决方法

PHP发送移动MAS短信乱码的解决方法

WBOY
WBOYOriginal
2016-06-23 13:39:201058Durchsuche

项目中需要使用到移动代理MAS短信的接口开发,但是厂家提供的开发包没有PHP的,只能使用DB接口,直接操作MYSQL。但是在短信发送后,手机接收到的短信确实乱码,琢磨了很久,大致判断应该是字符编码的问题。沿着这个方向不断琢磨、实验,最终找出了原因。

1、登录到mas机的mysql数据库,
使用命令:show variables like "%char%";
查看mysql数据库的字符编码:
 
  2、php使用如下:

mysql_connect('IP:3306','user','pwd');
mysql_select_db('mas');
mysql_query("set names latin1;");
mysql_query(mb_convert_encoding("insert into api_mt_db01(mobiles,content)values('".$mobiles."','".$content."');", "GB2312","UTF-8")); 
 其中set names latin1等同于
 SET character_set_client =  latin1;      

SET character_set_results =  latin1;     

SET character_set_connection =  latin1; 
3、项目中的字符编码是UTF-8,运行环境是windows 2008 ,其字符编码是GB2312,
由于latin1和utf8字符集不兼容,转换不可逆,所以必须把utf8转成gb2312,再把GB2312转成latin1

所以信息输入路径:app->os->client->connection->mysql,编码编码转换过程utf8->gb2312->latin1->latin1->latin1

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn