JavaShuo
栏目
标签
Android短彩信收发流程(Framework)
时间 2019-11-12
标签
android
彩信
收发
流程
framework
栏目
Android
繁體版
原文
原文链接
短信部分:
短信的发送,Framework部分从SmsManager的sendTextMessage(普通短信,无分段)与sendMultipartTextMessage(长短信,已分段)开始,一直到RIL。主要涉及到的类有。SmsManager、Isms、IccSmsInterfaceManager、SMSDispatcher、ImsSMSDispatcher、GsmSMSDispatcher、CdmaSMSDispatcher、SmsMessage、SmsTracker、CommandsInterface、BaseCommands、RIL、LocalSocket、RilRequest、Parcel等。
SmsManager->RIL:
sendTextMessage和sendMultipartTextMessage的过程其实差很少,无非是sendMultipartTextMessage对长短信进行了一下处理,为每个part设置了SmsHeader。ImsSMSDispatcher中包含了两种不一样的SmsDispatcher,IccSmsInterfaceManager调用SmsDispatcher中各个方法时,会根据手机类型的不一样,调用不一样SmsDispatcher的相应方法。大体过程为:一、计算编码方式;二、对每个分段构造SmsHeader、SubmitPdu、SmsTracker,并设置RadioTechnologyFamily;三、利用SmsTracker构造当消息正常发送后调用的Message对象;四、调用与手机卡类型有关的RIL中的相应方法发送。
RIL中发送:
sendImsGsmSms、sendSms、sendCdmaSms、sendImsCdmaSms这四个方法基本流程是大体相同的,都是先构造RILRequest,再调用send方法发送。区别就在于不一样的方法在得到RILRequest时传入的请求类型不一样,构造出来的pdu结构不一样,以及两个Ims方法须要先往RILRequest中写入一个数字。
发送后的处理:
已发送状态修改(sentIntent的调用过程)RILReceiver->SMSDispatcher:
在RIL的构造方法中,建立了一个RILReceiver对象,该对象实现了Runnable接口。它的做用是不停地从下层获取数据,分析类型,转到相应SMSDispatcher处理。
当短信经过LocalSocket发送出去后,因为是主动请求,下层会传上来一个响应,其基本类型为RESPONSE_SOLICITED,转入processSolicited处理。在该方法中,对于短信发送的处理,均调用responseSMS方法获取SmsResponse对象。(前面四种方式对应的事件类型为sendSMS-RIL_REQUEST_SEND_SMS、 sendCdmaSms-RIL_REQUEST_CDMA_SEND_SMS、sendImsGsmSms&sendImsCdmaSms-RIL_REQUEST_IMS_SEND_SMS)
而后建立AsyncResult对象,将SmsResponse对象与SmsTracker对象(SMSRequest中的)传入,更新以前在各个SMSDispatcher中建立的消息正常发送后调用的Message中的obj,设为建立的AsyncResult对象。将消息发送至相应SmsDispatcher处理。
已发送状态修改(sentIntent的调用过程)SMSDispatcher.handleMessage:
因为以前在构造Message对象时设置了what为SEND_SMS_COMPLETE,所以,此处调用handleSendComplete方法进行短信发送的后续处理。若须要发送报告,将SmsTracker加入deliveryPendingList中,这样后面收到发送报告时,可以从该列表中取出进行处理(具体参见应用层部分发送报告的处理)。
deliveryIntent(发送报告)RIL->SMSDispatcher:
对于GSM,在构造方法中,将GsmSMSDispatcher注册为RIL接收到发送报告时该事件的接收者,并设置消息类型为EVENT_NEW_SMS_STATUS_REPORT,相应的Registrant类为mSmsStatusRegistrant。
而对于CDMA,则设置消息类型为EVENT_NEW_SMS,相应的Registrant类为mCdmaSMSRegistrant。
当RIL收到底层传来的发送报告后(过程与已发送状态修改相同),会产生一个基本类型为RESPONSE_UNSOLICITED,转入processUnsolicited处理。
对于GSM,其事件类型为RIL_UNSOL_RESPONSE_NEW_SMS_STATUS_REPORT。先调用responseString从Parcel中获取数据,再调用mSmsStatusRegistrant的notifyRegistrant方法设置消息类型(what属性为EVENT_NEW_SMS_STATUS_REPORT)并转到SMSDispatcher进行处理。
而CDMA,事件类型为RIL_UNSOL_RESPONSE_CDMA_NEW_SMS。处理过程与GSM大体相同,只是从Parcel中获取数据是调用responseCdmaSms方法获取SmsMessage对象。而后调用mCdmaSMSRegistrant的notifyRegistrant方法设置消息类型(what属性为EVENT_NEW_SMS)并转到SMSDispatcher进行处理。
deliveryIntent(发送报告)SMSDispatcher:
对于GSM,直接调用handleStatusReport方法处理。从传入的AsyncResult对象中获取SmsMessage进而获取SmsTracker的索引,从deliveryPendingList中取出SmsTracker,发送deliveryIntent并发送消息确认。
对于CDMA,在handleMessage中转到EVENT_NEW_SMS。调用dispatchMessage进行消息的分发。
短信接收RIL->SMSDispatcher:
GSM,在构造方法中,将GsmSMSDispatcher注册为RIL接收短信时该事件的接收者,并设置消息类型为EVENT_NEW_SMS,相应的Registrant类为mSMSRegistrant。
CDMA,与发送报告相同,消息类型为EVENT_NEW_SMS,相应的Registrant类为mCdmaSMSRegistrant。
RILReceiver接收到短信后,会转到processUnsolicited进行处理。
对于GSM,其事件类型为RIL_UNSOL_RESPONSE_NEW_SMS。先调用responseString从Parcel中获取数据,再使用newFromCMT方法获取SmsMessage对象,最后调用mSMSRegistrant的notifyRegistrant方法设置消息类型(what属性为EVENT_NEW_SMS)并转到SMSDispatcher进行处理。
而CDMA,事件类型为RIL_UNSOL_RESPONSE_CDMA_NEW_SMS。过程与接收报告相同。
短信接收SMSDispatcher:
GSM,首先获取SmsHeader。
若是SmsHeader或SmsHeader.concatRef均不为空,说明是长短信,则调用processMessagePart将短信分段存入raw表,待全部分段都收到后,将其组装。而后根据端口的不一样,按照彩信通知(WapPushOverSms的dispatchWapPdu方法)、指定端口的彩信(dispatchPortAddressedPdus)、长短信(dispatchPdus)进行分发处理。
若SmsHeader或SmsHeader.concatRef有一个为空,说明不是长短信。而后根据端口的不一样,按照彩信通知(WapPushOverSms的dispatchWapPdu方法)、指定端口的彩信(dispatchPortAddressedPdus)、普通短信(dispatchPdus)进行分发处理。
GSM和CDMA的短信接收有很大一部分是相同的,只是CDMA因为标准定义的不一样,须要进行一些其余的处理。
CDMA没有相似GSM中的User Data Header(UDA)来存储一些额外信息,而是使用一个16位整数CDMA TELESERVICE来肯定消息的类型。
若是其为TELESERVICE_WAP,说明是CDMA彩信通知,则调用processCdmaWapPdu来处理。该方法的做用是将接收到的分段数据先存入raw表。只有当全部分段都接收到后,若是端口是WAP_PUSH的彩信,才调用WapPushOverSms的dispatchWapPdu方法将彩信通知内容解码后经过广播发送到应用层。不然,调用dispatchPortAddressedPdus方法将其发送到指定端口(sms://localhost:port)。
另外,CDMA中提供了一种cmas消息。若是是这种消息,当收到时,当即调用dispatchBroadcastPdus方法发送紧急广播。
彩信接收:
在Android中,彩信的接收分为两部分。彩信通知经过短信的方式接收,如上文所述。彩信数据的
下载
在应用层中处理。
相关文章
1.
Android短彩信收发流程(Framework)
2.
Android Mms专题之:Android短彩信收发流程(Framework)
3.
Android短彩信收发流程(应用层)
4.
Android短彩信源码解析-短信发送流程(二)
5.
Android 短信 彩信 wap push的接收
6.
Android Mms之短信接收流程--从Framework到App
7.
短信发送--短信的发送流程(framework)
8.
Android 收发彩信(MMS)
9.
mtk短信接收流程
10.
Android 收发短信 (8.2)
更多相关文章...
•
Lua 流程控制
-
Lua 教程
•
Git 工作流程
-
Git 教程
•
PHP开发工具
•
JDK13 GA发布:5大特性解读
相关标签/搜索
发短信
短信发送
彩信
短信
收信
framework
收发
发信
流程
Android
浏览器信息
Docker教程
Docker命令大全
教程
开发工具
0
分享到微博
分享到微信
分享到QQ
每日一句
每一个你不满意的现在,都有一个你没有努力的曾经。
最新文章
1.
「插件」Runner更新Pro版,帮助设计师远离996
2.
错误 707 Could not load file or assembly ‘Newtonsoft.Json, Version=12.0.0.0, Culture=neutral, PublicKe
3.
Jenkins 2018 报告速览,Kubernetes使用率跃升235%!
4.
TVI-Android技术篇之注解Annotation
5.
android studio启动项目
6.
Android的ADIL
7.
Android卡顿的检测及优化方法汇总(线下+线上)
8.
登录注册的业务逻辑流程梳理
9.
NDK(1)创建自己的C/C++文件
10.
小菜的系统框架界面设计-你的评估是我的决策
本站公众号
欢迎关注本站公众号,获取更多信息
相关文章
1.
Android短彩信收发流程(Framework)
2.
Android Mms专题之:Android短彩信收发流程(Framework)
3.
Android短彩信收发流程(应用层)
4.
Android短彩信源码解析-短信发送流程(二)
5.
Android 短信 彩信 wap push的接收
6.
Android Mms之短信接收流程--从Framework到App
7.
短信发送--短信的发送流程(framework)
8.
Android 收发彩信(MMS)
9.
mtk短信接收流程
10.
Android 收发短信 (8.2)
>>更多相关文章<<