用VB6.0编写手机短信发送

2016-02-19 21:47 73 1 收藏

有了下面这个用VB6.0编写手机短信发送教程,不懂用VB6.0编写手机短信发送的也能装懂了,赶紧get起来装逼一下吧!

【 tulaoshi.com - 编程语言 】

  因为手机短消息的发送是以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格式,下面的函数就是为了实现这种转换: 

  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  

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  手机号码有两种表示方法: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指令介绍部分)。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  为了防止手机因过于繁忙而出错,这里采取了一定的方法让手机有充分的时间处理发送和接收及删除等操作。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 

  2 手机短信接收函数 

  相对于短信的发送函数而言,短信的接收相当简单,只需要以下的三行代码就完成了。但是它使用的技术却决不比短信的发送少,这里主要用到了Mscomm控件的Output属性和AT+CMGR指令。 

  Public Sub readsms(rnum As String)
  mobcomm.Output = "AT+CMGF=1" + vbCr
  mobcomm.Output = "AT+CMGR=" & rnum + vbCr
  End Sub 

来源:https://www.tulaoshi.com/n/20160219/1627155.html

延伸阅读
在利用VB开发MIS系统的过程中,经常需要制作动态统计报表。本文就如何实现动态数据源下的分组交叉统计报表进行阐述,并结合实例给出编程指导。 在VB6.0的数据环境设计器中,我们可以利用“添加命令”一项来连接报表所需的数据源,同时利用“添加命令”属性中的分组与合计功能设计分组交叉统计报表的数据源,至此我们可以设计简单的数据存在...
标签: vb
TreeView是最灵活的Windows控件之一,它以分层的形式显示数据,允许用户随意扩展或折叠节点。鉴于实际生活中许多事物有着层次关系,如计算机里的文件夹、人事组织关系、地区从属关系等,TreeView的应用也极其广泛。但在实际开发中,许多人不喜欢使用TreeView,主要是由于默认的TreeView是“只读”的,不支持添加、删除、编辑、调整节点位...
iPhone手机短信使用技巧   随着微信、QQ等移动通讯应用的普及,手机短信在一些用户严厉已经不那么的重要了,不过当用户需要传递重要信息的话,我们还是应当使用短信来保证信息能够正常被传递,不过对于iPhone手机用户来说,有很多您不知道的技巧,下面我们来看下吧! 信息检索 在信息页面,下拉屏幕就可以呼出搜索栏。...
标签: Android
安卓手机短信怎么备份   1.打开百度云,点击窗口界面的右上方下拉菜单中的设置一项 2.你会看到许多实用的手机云端备份功能,其中就有我们需要的短信备份功能。点击短信备份恢复 3图老师.之后就可以看到当前手机上的短信数量,选择备份到云端。就可以备份对你有价值的 短信 4. 最后,当你需要这些短信时,可以...
标签: Android
安卓手机短信备份图解   1.打开百度云,点击窗口界面的右上方下拉菜单中的设置一项 www.Tulaoshi.com 2.你会看到许多实用的手机云端备份功能,其中就有我们需要的短信备份功能。点击短信备份恢复 3.之后就可以看到当前手机上的短信数量,选择备份到云端。就可以备份对你有价值的 短信 4. 最后,当你需要这些短...

经验教程

340

收藏

50
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部