快速检索
  气象   2008, Vol. 34 Issue (10): 115-117.  

技术交流

引用本文 [复制中英文]

杨荣芳, 屈玉贵, 2008. 浅析手机气象短信息乱码的问题[J]. 气象, 34(10): 115-117. DOI: .
[复制中文]
2008. [J]. Meteorological Monthly, 34(10): 115-117. DOI: .
[复制英文]

文章历史

2007年12月18日收稿
2008年8月29日收修定稿
浅析手机气象短信息乱码的问题
杨荣芳 1,2, 屈玉贵 1    
1. 中国科学技术大学电子工程与信息科学系, 合肥 230026
2. 河北省气象科技服务中心
摘要:随着GSM (global system for mobile communication)短信息服务(short message service,SMS)的推广和应用,手机短信已经成为气象信息服务传播的重要渠道。但是在为用户提供气象信息服务中,经常会出现用户手机收到的气象短信为乱码的现象。介绍了有关手机短信编码的规则,发生接收短信息乱码的原因,并结合实际应用提出了相关的解决方法。
关键词手机短信    短信编码    乱码    
Abstract:
引言

随着计算机技术、无线通信网络技术的不断发展,短信以其成本低的特性,迅速发展为企业向客户提供服务的主要通道和手段,其惊人的发展速度,无疑创造了“拇指经济”的神话。气象短信服务在此背景下应运而生,很快发展成为短信行业的领头军。但是在为客户提供气象短信息服务的同时,也出现用户由于接收信息不正常而引发的各种投诉问题,如接收不到、接收信息显示不正常等。因此,保证客户短信息的接收质量成为短信稳定发展的关键问题。

通过对公众气象短信投诉的分析,影响气象短信服务质量的因素有很多,在保证气象短信正常准确发送的情况下,短信息乱码是用户投诉的原因之一。短信息出现乱码基本原理都是由于信息编码和解码不统一所致。本文主要从手机用户发送和接收短信息乱码方面,介绍乱码产生的原因、表现形式及其解决方法,解读不同字符集的相互转换。

1 短信息编码的模式

手机发送短消息常用Text和PDU(Protocol Data Unit,协议数据单元)模式。使用Text模式收发短信代码简单,实现起来十分容易,但Text模式只能发送普通的ASCII字符,最大的缺点是不能收发中文短信;而PDU模式不仅支持中文短信,也能发送英文短信。目前,气象短信息服务主要是以文本、数字或二进制数据为主,主要采用PDU模式,这种短消息的长度被限定在140字节之内,即70个中文字符。中文短消息的编码实现较简单,只需将GB2312的中文编码转换为代码页为CP936的Unicode编码即可。如表 1[1]所示。

表 1 中文编码的实现过程
1.1 PDU编码规则

PDU模式收发短信可以使用3种编码:7bit、8bit和UCS2编码[2]。7bit编码用于发送普通的ASCII字符,它将一串7bit的字符(最高位为0)编码成8bit的数据,每8个字符可“压缩”成7个;8bit编码通常用于发送数据消息,比如图片和铃声等;UCS2编码用于发送Un icode字符。7bit编码时,指原始短消息的字符个数,而不是编码后的字节数。如果用户信息(TP-UD)中存在一个头(基本参数的TP-UDHI为1),在所有编码方式下,用户信息长度(TP-U DL)都等于头长度与编码后字节数之和。如果采用GSM 03.42所建议的压缩算法(TP-DCS的高3位为001),则该长度也是压缩编码后字节数或头长度与压缩编码后字节数之和。目前普遍使用的为文本短信息,所以采用的为Unicode字符中的UCS2编码。PDU串的用户信息(TP-UD)段最大容量是140字节,所以在这种编码方式下,可以发送的短消息的最大字符数为140个。一般的PDU编码由A—M十三项组成。

A:短信息中心地址长度,2位十六进制数(1字节)。

B:短信息中心号码类型,2位十六进制数。

C:短信息中心号码,B+C的长度将由A中的数据决定。

D:文件头字节,2位十六进制数。

E:信息类型,2位十六进制数。

F:被叫号码长度,2位十六进制数。

G:被叫号码类型,2位十六进制数,取值同B。

H:被叫号码,长度由F中的数据决定。

I:协议标识,2位十六进制数。

J:数据编码方案,2位十六进制数。

K:有效期,2位十六进制数。

L:用户数据长度,2位十六进制数。

M:用户数据,其长度由L中的数据决定。J中设定采用UCS2编码,这里是中英文的Unicode字符。

1.2 手机短信息出现乱码的现象及其原因 1.2.1 手机收到空的短信息

当发送方信息已经发出,而接收方手机没有收到或者收到为空信息。前者是由于短信在传输路径上发送失败,原因有很多,其中主要的有三种情况,第一种情况为手机用户在网关鉴权失败,此用户的正常服务受限制,不能为其进行短信服务;或者短信在传输时延时太长,超过了它存在的生命周期而被系统抛弃;最后一种情况如果手机用户不在服务区或者关机,也不能接收到短信。

当手机用户收到短信息,但信息内容为空,主要是因为发送方信息编码与接收方解码不一致造成,当接收信息为空时,一般是因为手机不支持此种字符无法显示,或者因为手机用户没有对文字信息字符显示进行设置。

1.2.2 手机收到短信息不完整

有时手机只收到部分短信息内容,这是由于短信息本身采用PDU编码模式造成。采用PDU编码模式,加之受到手机机型的限制,一般手机支持发送短信在70个汉字或140个英文字符(标点作为汉字字符),因此如果超出这个长度,短信内容将被自动截去超长的部分,只收到允许长度范围内的内容。

1.2.3 手机收到短信息为乱码

当手机收到短信息为无法辨认的字符时,一般意义称为乱码。这种乱码和收到空信息的基本原理时一样的,都是由于发送方信息编码与接收方解码不一致造成,使解码出来的短信息不正确,从而无法正常显示。

2 手机短信息乱码的解决方法

对于手机收到短信息乱码的问题,可以从发送方和接收方两方面进行解决。一方面,是手机本身造成的原因;另一方面,由于发送方的原因生成乱码。

2.1 手机本身造成的乱码

一种情况为:用户的手机本身有缺陷(非中国区销售的手机),由于手机汉字内码不一样,在接收中文短消息是会造成接收乱码;另一种情况可能是由于手机不支持中文短消息引起的。还有某些型号手机虽然能显示中文,但却无法显示中文标点,会出现手机收到空信息或者乱码。针对手机本身造成乱码的情况,如果在手机本身设置为支持全部字符情况下,收到的短信息仍为乱码,一般建议用户更换手机或者尽量不采用易出现乱码的字符。

2.2 发送方原因造成的乱码

发送方首先要把发送的信息长度控制在手机允许接收短信长度范围之内。一般小灵通手机的一条短信长度是45到56个中文字左右;手机短消息最长为160个英文字母(包括数字)或者70个汉字字符或汉字英文混合字符,但不同型号的手机可能会有不同的限制,所以一般在短信息长度超过140字符数时,即超长短信,有些手机不支持长短信,超长部分信息会被系统自动截断,或者为乱码,造成用户接收信息不完整。

发送方在发送信息时,一定要选择正确的编码格式。由于气象短信息发送的为中文短信息,因此在发送信息时,一定要选择UCS2编码,即中文Unicode码。接收方不仅收到UCS2格式编码的PDU串,也有可能是7bit编码格式(TP-DCS为00)或8bit编码格式(TP-DCS为04)的PDU串,对于此情况,接收方一定要选择相应的算法进行解码。

3 小结

为了避免在发送气象短信息时,用户收到气象短信乱码的现象,就必须在发送短信息时,采用正确的编码格式和规范的短信长度,尽量使用通用手机类型,以保证短信用户接收信息的准确性,从而使气象短信服务做得更好。

参考文献
[1]
徐彦琦, 刘雅睛, 黄登山. 基于GSM短消息的编解码及编码实现[J]. 通信技术, 2006-10-18: 56-58. http://kns.cnki.net/KCMS/detail/detail.aspx?filename=txbm200705030&dbname=CJFD&dbcode=CJFQ
[2]
王晋海, 刘光昌. 短信息服务SMS的开发[J]. 计算机工程与设计, 2003-02-22: 77-79 http://kns.cnki.net/KCMS/detail/detail.aspx?filename=sjsj200307022&dbname=CJFD&dbcode=CJFQ
[3]
亓莱滨. 《Unicode内码转换与汉字乱码》[M]. 北京: 电脑知识与技术: 158-160.