资源描述:
《通过串口实时接收短消息》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、一年前本人曾写过“通过串口收发短消息(上)、(下)”两篇文章,讨论了在TE(PC、单片机系统等)上利用扩展的AT指令控制ME(手机,GSM模块等)发送和接收短消息的基本方法。其中接收/阅读短消息采用主动查询的方法。TE发送“AT+CMGL”指令,ME则输出已接收和存储的短消息。这比较符合AT指令集的精神:有问有答,一问一答。但在实际应用中,发现这种方法存在一定的缺点:ME接收到消息并存储起来,待查询时再传输到TE,中间总会有一段时间的延迟。这个延迟取决于查询间隔。发出该指令后,不论ME里有没有,有多少条消息,总要经过长时间的延迟TE才能收到最终的
2、“OK”。完整的过程一般持续5-10秒。本文介绍一种通过串口“实时”接收短消息的方法。当ME收到一条消息时,主动发出通知给TE,或者直接将消息转发到TE。与查询机制相比,它类似于中断机制。先简要说明一下短消息类(class)的概念:根据指定储存的位置,短消息分为class0–3四个类。也可以不指定类(noclass),由ME按默认设置进行处理,存储到内存或者SIM卡中。在TPDU的TP-DCS字节中,当bit7-bit4为00x1,01x1,1111时,bit1-bit0指出消息所属类:00–class0:只显示,不储存01–class1:储存在
3、ME内存中02–class2:储存在SIM卡中03–class3:直接传输到TEGSMModem一般都支持一条“AT+CNMI”指令,可用于设定当有某类短消息到达时,如何处置它:只储存在指定的内存(易失的/非易失的)中,先储存后通知TE,还是直接转发到TE,等等。“AT+CNMI”指令语法为AT+CNMI=[[,[,[,[,]]]]]mode-通知方式:0–不通知TE。1–只在数据线空闲的情况下,通知TE;否则不通知TE。2–通知TE。在数据线被占用的情况下,先缓冲起来,待数据线空闲,再行通知。3–通
4、知TE。在数据线被占用的情况下,通知混合在数据中一起传输。mt-消息储存或直接转发到TE:0–储存到默认的内存位置(包括class3)1–储存到默认的内存位置,并且向TE发出通知(包括class3)2–对于class2,储存到SIM卡,并且向TE发出通知;对于其它class,直接将消息转发到TE3–对于class3,直接将消息转发到TE;对于其它class,同mt=1bm,ds,bfr的含义,请参考相关标准文档。一般不需要去关心它们。在程序中具体实现时,使用mode=2,mt=1,比较简单。对所有类型的短消息,只要在收到ME送来的“+CMTI”通
5、知后,用“AT+CMGR”指令读取消息内容就行了。TE与ME之间的通信过程,举例如下:(初始化)AT+CNMI=? (查看能支持的设置范围)+CNMI:(0-2),(0-3),(0,2,3),(0,1),(0,1)OKAT+CNMI? (查看当前设置)+CNMI:0,0,0,0,0OKAT+CNMI=2,1 (设置为mode=2,mt=1)OKAT+CNMI? (再查看当前设置)+CNMI:2,1,0,0,0OK(过了一段时间,有一条消息到达)+CMTI“ME”,8 (通知:消息已经存储在ME内存中,序号为8)AT+CMGR=8 (读第8
6、条消息)+CMGR:8,270891683108200505F0240D91683158812764F80000402052110373800741E19058341E01OKAT+CMGD=8 (删除第8条消息)OK还有一种方式mode=2,mt=2也很令人感兴趣。在这种方式下,除了class2外,消息不存储,直接转发到TE。需要处理消息通知和内容两种情况,复杂一些。但如果发送方也由程序控制,可以只发noclass或class1的消息,这样不存储在接收方ME内存(一般是闪存,非易失性的)中,肯定能延长它的使用寿命。TE与ME之间的通信过程,举例
7、如下:AT+CNMI=2,2 (设置为mode=2,mt=2)OK(过了一段时间,有一条消息到达)+CMT:,260891683108200505F0040D91683158812764F8000840205211639180064F60597D0021