欢迎来到天天文库
浏览记录
ID:5645457
大小:29.00 KB
页数:6页
时间:2017-12-21
《visual basic设计手机短信收发程序》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、用VisualBasic设计手机短信收发程序中文转换成Unicode码函数 因为手机短消息的发送是以PDU串的形式发送出去的,中文字符以Unicode码来表示,所以在发送中文短消息之前必须首先将中文字符转换为Unicode码,下面的函数将实现这个功能。这个函数主要应用到VB自带的一个格式转换函数:ChrW()将中文转换为Unicode代码。PublicFunctionchg(rmsgAsString)AsString DimtepAsString DimtempAsString DimiAsInteger DimbAsInteger
2、 tep=rmsg i=Len(tep) b=i/4 Ifi=b*4Then b=b-1 tep=Left(tep,b*4) Else tep=Left(tep,b*4) EndIf chg="" Fori=1Tob temp="&H"&Mid(tep,(i-1)*4+1,4) chg=chg&ChrW(CInt(Val(temp))) NextiEndFunctioncode码。 短信中心手机号码的PDU串转换函数 同上,为了发送以PDU模式发送短消息,必须将手机号码和对方手机号码也转换为PDU格式,下面的函数就是为了
3、实现这种转换:PublicFunctiontelc(numAsString)AsString DimtlAsInteger Dimltem,rtem,ttemAsString DimtiAsInteger ttem="" tl=Len(num) Iftl<>11Andtl<>13Then MsgBox"wrongnumber."&tl ExitFunction EndIf Iftl=11Then tl=tl+2 num="86"&num EndIf Forti=1TotlStep2 ltem=Mid(num,ti,1) r
4、tem=Mid(num,ti+1,1) Ifti=tlThenrtem="F" ttem=ttem&rtem<em Nextti telc=ttemEndFunction 手机号码有两种表示方法:11位和13位(带国家码86),一般手机发送时都是以13位形式表示的,所以以上的函数还有一个功能是自动将11位格式手机号码转换为13位形式,然后再转换为PDU串。 手机短信的发送 手机短信的发送主要借助于VB的Mscomm控件实现,关于Mscomm控件,前面的技术介绍部分有详细介绍。短信的发送是由AT+CMGS指令完成的,采用P
5、DU模式发送,函数代码如下:Constprex="0891"Constmidx="11000D91"Constsufx="000800"PublicFunctionSendsms(cscaAsString,numAsString,msgAsString)As_Boolean Dimpdu,psmsc,pnum,pmsgAsString DimlengAsString DimlengthAsInteger length=Len(msg) length=2*length leng=Hex(length) Iflength<16Thenle
6、ng="0"&leng psmsc=Trim(telc(csca)) pnum=Trim(telc(num)) pmsg=Trim(ascg(msg)) pdu=prex&psmsc&midx&pnum&sufx&leng&pmsg sleep(1) mobcomm.Output="AT+CMGF=0"+vbCr mobcomm.Output="AT+CMGS="&Str(15+length)+vbCr mobcomm.Output=pdu&Chr$(26) sleep(1) Sendsms=TrueEndFunction 因为手机
7、同一时间只能处理一件事情,因此这个函数只负责发送短信,关于短信发送成功与否以及阅读短信的部分集中在一起处理。判断手机短信发送成功与否主要由AT+CMGS命令执行以后的返回码来决定(可参见前文的AT指令介绍部分)。 为了防止手机因过于繁忙而出错,这里采取了一定的方法让手机有充分的时间处理发送和接收及删除等操作。Sleep()函数正是为此而设计的,在发送及删除操作后都会让程序暂停一秒,这样就不至于使得手机过于繁忙。 手机短信的接收 Unicode码解码函数 相比于手机短信的发送而言,手机短信的接收主要的工作正好与之相反。手机短信的
8、发送需要将待发送的短信内容转换为Unicode码,而短信的接收则需要将接收到的Unicode码转换成中文字符。下面的函数将实现解码功能。同手机短信发送的编码函数一样,这里也应用了一个VB内置的函数AscW()函数来将Un
此文档下载收益归作者所有