转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 软件开发 >> VB.NET程序 >> 正文
用Visual Basic设计手机短信收发程序         ★★★★

用Visual Basic设计手机短信收发程序

作者:闵涛 文章来源:闵涛的学习笔记 点击数:627 更新时间:2009/4/23 15:03:13
  中文转换成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命令执行以后的返回码来决定(可参见前文的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 + vbCr

End Sub


[VB.NET程序]用Visual Basic创建复杂窗体  [VB.NET程序]用Visual Basic编程建立自己的回收站
[VB.NET程序]用Visual Basic 6.0实现自动化测试  [VB.NET程序]用Visual Basic学做“黑客”程序
[VB.NET程序]用Visual Basic实现undo功能  [VB.NET程序]用Visual Basic为软件增加注册功能
[VB.NET程序]用Visual Basic设计个性化文件夹图标  [VB.NET程序]用Visual Basic6.0实现电影特效
[VB.NET程序]用Visual Basic设计抽奖程序  [VB.NET程序]用Visual Basic进行多媒体设计
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · C语言系列  · VB.NET程序
    · JAVA开发  · Delphi程序
    · 脚本语言
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台