为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

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

2017-10-05 6页 doc 19KB 12阅读

用户头像

is_594905

暂无简介

举报
用Visual Basic设计手机短信收发程序用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 Di...
用Visual Basic设计手机短信收发程序
用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命令执行以后的返回码来决定(可参见前文的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
/
本文档为【用Visual Basic设计手机短信收发程序】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索