手机短信收发

原创 2004年04月22日 14:36:00

手机短信发送<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

²        中文转换成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串。

 

²        手机短信的发送

 

手机短信的发送主要借助于VBMscomm控件实现,关于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

 

android broadcast学习之监控他人手机接收的短信

废话不多说,上代码先: 程序启动时调用的activity,在该activity中创建一个不绑定的service(防止程序退出后监控程序被关闭):package com.demo.broadcast;...
  • HYW332147617
  • HYW332147617
  • 2014年02月19日 17:22
  • 1207

sms收发手机短信

     这几天在试VS2005里面的SerialPort 类,这个类主要功能是串口通信,以前没接触串口这方面的知识,一开始还比较吃力,还好现在清楚了大半利用这个类做了一个sms收发手机短信的demo...
  • duncansun
  • duncansun
  • 2006年04月21日 09:42
  • 5147

使用USB收发手机短信

现在很多关于串口RS232的手机收发短信程序,但很少有USB的程序,发个方案和大家分享。手机要求:该生产商提供了USB的驱动程序,motorola的可以到http://developer.motoro...
  • chinadolls00
  • chinadolls00
  • 2007年11月05日 11:45
  • 708

C#简单实现发送手机短信

偶然想起,像编写一个从电脑向手机发送短信的程序,从网上查找到有三种方式:(1)使用webservice接口发送手机短信,这个可以使用sina提供的webservice进行发送,但是需要进行注册;(2)...
  • huang9012
  • huang9012
  • 2014年04月11日 11:21
  • 941

关于手机短信收发程序中间件

在目前我了解到的关于手机短信中间件,国内好象还没有一个这样比较统一的说法,更多的是说成是短信二次开发或短信开发接口。下面说说关于短信收发程序中间件的研究步骤:(我的一些经验.NET 2.0平台)一、先...
  • youareok
  • youareok
  • 2009年03月15日 13:17
  • 211

支付宝小程序手机验证码,小程序短信验证码开发

虽然支付宝小程序可以通过my.chooseAlipayContact(), 获取支付宝通讯录联系人的手机号码, 但是有些情况, 还是想要通过短信验证码的方式, 来确认用户填写的手机号码的真实性...
  • towtotow
  • towtotow
  • 2018年01月04日 19:21
  • 3338

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

文转换成Unicode码函数   因为手机短消息的发送是以PDU串的形式发送出去的,中文字符以Unicode码来表示,所以在发送中文短消息之前必须首先将中文字符转换为Unicode码,下面的函数将实现...
  • ssihc0
  • ssihc0
  • 2008年10月15日 23:54
  • 528

获取手机短信

在做手机应用中,常常会碰到要求获取手机短信需求。所以记录下来,有需要的可以一看~! 因为获取短信肯定不止一条,所以我们定义的一个方法,获取返回一个list. 然后liist里面装一个javabea...
  • lx448593jp
  • lx448593jp
  • 2015年12月22日 16:22
  • 581

在Linux下用C语言实现短信收发

去年在博客里发这个贴时,只将主程序代码贴了出来,导致信息不完整,让读者根本无法进行实验。为此,现将全部代码贴出来,为想在linux下开发基于短信猫的短信收发程序的朋友提供一点参考。    首先,我根据...
  • lyserver
  • lyserver
  • 2008年10月01日 12:55
  • 5942

51单片机项目制发短信

#include #include #define Buf_Max 100 //缓存长度100 #define Delay_Time 2000  //延时长度 sbit LED...
  • qq_21792169
  • qq_21792169
  • 2015年09月30日 21:45
  • 3371
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:手机短信收发
举报原因:
原因补充:

(最多只允许输入30个字)