用VisualBasic的设计手机短信收发程序.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用Visual Basic设计手机短信收发程序   中文转换成Unicode码函数   因为手机短消息的发送是以PDU串的形式发送出去的,中文字符以Unicode码来表示,所以在发送中文短消息之前必须首先将中文字符转换为Unicode码,下面的函数将实现这个功能。这个函数主要应用到VB自带的一个格式转换函数:ChrW()将中文转换为Unicode码。 Public Function chg(rmsg As String) As String  Dim tep As String  Dim temp As String  Dim i As Integer  Dim b As Integer  tep = rmsg  i = Len(tep)  b = i / 4  If i = b * 4 Then   b = b - 1   tep = Left(tep, b * 4)  Else   tep = Left(tep, b * 4)  End If  chg =  For i = 1 To b   temp = H Mid(tep, (i - 1) * 4 + 1, 4)   chg = chg ChrW(CInt(Val(temp)))  Next i End Function   短信中心手机号码的PDU串转换函数   同上,为了发送以PDU模式发送短消息,必须将手机号码和对方手机号码也转换为PDU格式,下面的函数就是为了实现这种转换: Public Function telc(num As String) As String  Dim tl As Integer  Dim ltem, rtem, ttem As String  Dim ti As Integer  ttem =  tl = Len(num)  If tl 11 And tl 13 Then   MsgBox wrong number. tl   Exit Function  End If  If tl = 11 Then   tl = tl + 2   num = 86 num  End If  For ti = 1 To tl Step 2   ltem = Mid(num, ti, 1)   rtem = Mid(num, ti + 1, 1)   If ti = tl Then rtem = F   ttem = ttem rtem ltem  Next ti  telc = ttem End Function   手机号码有两种表示方法:11位和13位(带国家码86),一般手机发送时都是以13位形式表示的,所以以上的函数还有一个功能是自动将11位格式手机号码转换为13位形式,然后再转换为PDU串。   手机短信的发送   手机短信的发送主要借助于VB的Mscomm控件实现,关于Mscomm控件,前面的技术介绍部分有详细介绍。短信的发送是由AT+CMGS指令完成的,采用PDU模式发送,函数代码如下: Const prex = 0891 Const midx = 11000D91 Const sufx = 000800 Public Function Sendsms(csca As String, num As String, msg As String) As _Boolean  Dim pdu, psmsc, pnum, pmsg As String  Dim leng As String  Dim length As Integer  length = Len(msg)  length = 2 * length  leng = Hex(length)  If length 16 Then leng = 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 = True End Function   因为手机同一时间只能处理一件事情,因此这个函数只负责发送短信,关于短信发送成功与否以及阅读短信的部分集中在一起处理。判断手机短信发送成功与否主要由AT+CMGS命令执行以后的返回码来决定(可参见前文的

文档评论(0)

shaoye348 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档