开发学院软件开发VC 通过串口实时接收短消息 阅读

通过串口实时接收短消息

 2010-07-20 20:45:58 来源:WEB开发网   
核心提示:一年前本人曾写过“通过串口收发短消息(上)、(下)”两篇文章,讨论了在TE(PC、单片机系统等)上利用扩展的AT指令控制ME(手机,通过串口实时接收短消息,GSM模块等)发送和接收短消息的基本方法,其中接收/阅读短消息采用主动查询的方法,同mt=1bm, ds, bfr的含义,请参考相关标准文档

一年前本人曾写过“通过串口收发短消息(上)、(下)”两篇文章,讨论了在TE(PC、单片机系统等)上利用扩展的AT指令控制ME(手机,GSM模块等)发送和接收短消息的基本方法。其中接收/阅读短消息采用主动查询的方法。TE发送“AT+CMGL”指令,ME则输出已接收和存储的短消息。这比较符合AT指令集的精神:有问有答,一问一答。但在实际应用中,发现这种方法存在一定的缺点:

ME接收到消息并存储起来,待查询时再传输到TE,中间总会有一段时间的延迟。这个延迟取决于查询间隔。

发出该指令后,不论ME里有没有,有多少条消息,总要经过长时间的延迟TE才能收到最终的“OK”。完整的过程一般持续5-10秒。

本文介绍一种通过串口“实时”接收短消息的方法。当ME收到一条消息时,主动发出通知给TE,或者直接将消息转发到TE。与查询机制相比,它类似于中断机制。

先简要说明一下短消息类(class)的概念:根据指定储存的位置,短消息分为class 0 – 3四个类。也可以不指定类(no class),由ME按默认设置进行处理,存储到内存或者SIM卡中。在TPDU的TP-DCS字节中,当bit7-bit4为00x1, 01x1, 1111时,bit1-bit0指出消息所属类:

00 – class 0:只显示,不储存

01 – class 1:储存在ME内存中

02 – class 2:储存在SIM卡中

03 – class 3:直接传输到TE

GSM Modem一般都支持一条“AT+CNMI”指令,可用于设定当有某类短消息到达时,如何处置它:只储存在指定的内存(易失的/非易失的)中,先储存后通知TE,还是直接转发到TE,等等。

“AT+CNMI”指令语法为

AT+CNMI=[<mode>[,<mt>[,<bm>[,<ds>[,<bfr>]]]]]

mode - 通知方式:

0 – 不通知TE。

1 – 只在数据线空闲的情况下,通知TE;否则不通知TE。

2 – 通知TE。在数据线被占用的情况下,先缓冲起来,待数据线空闲,再行通知。

3 – 通知TE。在数据线被占用的情况下,通知混合在数据中一起传输。

mt - 消息储存或直接转发到TE:

0 – 储存到默认的内存位置(包括class 3)

1 – 储存到默认的内存位置,并且向TE发出通知(包括class 3)

2 – 对于class 2,储存到SIM卡,并且向TE发出通知;对于其它class,直接将消息转发到 TE

3 – 对于class 3,直接将消息转发到 TE;对于其它class,同mt=1

bm, ds, bfr的含义,请参考相关标准文档。一般不需要去关心它们。

1 2  下一页

Tags:通过 串口 实时

编辑录入:爽爽 [复制链接] [打 印]
[]
  • 好
  • 好的评价 如果觉得好,就请您
      0%(0)
  • 差
  • 差的评价 如果觉得差,就请您
      0%(0)
赞助商链接