好文档就是一把金锄头!
欢迎来到金锄头文库![会员中心]
电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

自-用Visual Basic设计手机短信收发程序.doc

4页
  • 卖家[上传人]:洛**
  • 文档编号:190954559
  • 上传时间:2021-08-13
  • 文档格式:DOC
  • 文档大小:16KB
  • / 4 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 用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 iEnd 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命令执行以后的返回码来决定(可参见前文的AT指令介绍部分)ﻫ  为了防止因过于繁忙而出错,这里采取了一定的方法让有充分的时间处理发送和接收及删除等操作Sleep()函数正是为此而设计的,在发送及删除操作后都会让程序暂停一秒,这样就不至于使得过于繁忙ﻫ  短信的接收ﻫ  Unicode码解码函数ﻫ  相比于短信的发送而言,短信的接收主要的工作正好与之相反短信的发送需要将待发送的短信内容转换为Unicode码,而短信的接收则需要将接收到的Unicode码转换成中文字符下面的函数将实现解码功能同短信发送的编码函数一样,这里也应用了一个VB内置的函数AscW()函数来将Unicode码转换为中文:Public Function ascg(smsg As String) As Stringﻫ Dim si, sb As Integer Dim stmp As Integer Dim stemp As String sb = Len(smsg)ﻫ ascg = "" For si = 1 To sb  stmp = AscW(Mid(smsg, si, 1))ﻫ  If Abs(stmp) < 127 Thenﻫ  stemp = "00" & Hex(stmp) Elseﻫ   stemp = Hex(stmp)  End Ifﻫ  ascg = ascg & stempﻫ Next siﻫ ascg = Trim(ascg)End Functionﻫ  短信接收函数ﻫ  相对于短信的发送函数而言,短信的接收相当简单,只需要以下的三行代码就完成了。

      但是它使用的技术却决不比短信的发送少,这里主要用到了Mscomm控件的Output属性和AT+CMGR指令Public Sub readsms(rnum As String)ﻫ mobcomm.Output = "AT+CMGF=1" + vbCrﻫ mobcomm.Output = "AT+CMGR=" & rnum + vbCrEnd Sub。

      点击阅读更多内容
      关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
      手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
      ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.