短信部分:
短信的发送,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的相应方法。大致过程为:1、计算编码方式;2、对每一个分段构造SmsHeader、SubmitPdu、SmsTracker,并设置RadioTechnologyFamily;3、利用SmsTracker构造当消息正常发送后调用的Message对象;4、调用与手机卡类型有关的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中,彩信的接收分为两部分。彩信通知通过短信的方式接收,如上文所述。彩信数据的下载在应用层中处理。
- 大小: 42.1 KB
- 大小: 95.3 KB
- 大小: 27.2 KB
- 大小: 47.3 KB
- 大小: 28.8 KB
- 大小: 52.8 KB
- 大小: 85.8 KB
- 大小: 27.2 KB
- 大小: 52.8 KB
- 大小: 85.8 KB
分享到:
相关推荐
### 彩信收发流程分析方法详解 #### 一、彩信接收分析 彩信接收流程涉及复杂的信令交互,其分析对理解网络性能及优化至关重要。以下是对彩信(1.0)与彩信(2.0)接收流程的深入解析。 ##### 1.1 彩信(1.0)接收...
Android MMS 彩信发送代码流程详解 Android MMS 彩信发送代码流程是 Android 操作系统中一个复杂的过程,涉及到多个应用层和系统服务的交互。下面将对该过程进行详细解释,从 Messaging 应用层到 framework 应用层...
本文将基于提供的彩信收发原理图,详细介绍彩信的收发流程及其背后的运作机制。 #### 二、彩信系统组成与工作原理 ##### 1. 系统组成 彩信系统的正常运行依赖于一系列组件和网络设施的支持,主要包括: - **终端...
最简单的android彩信发送代码。适合学习彩信发送流程。 事实上android中的Mms模块中,对这个流程进行了很少的封装,这里就是将其简化,帮助初学者了解流程。
**MMS彩信业务流程及代码实现** MMS(Multimedia Messaging Service)即多媒体信息服务,是一种在移动网络中发送和接收包含文本、图像、音频、视频等多媒体内容的消息服务。与传统的SMS短信相比,MMS提供了更为丰富...
1.1彩信(1.0)接收信令流程分析 1.1.1 信令过程异常分析 1.1.2 成功率分析 1.1.3 彩信接收失败原因分析 1.1.3.1 timeout 失败原因分析 1.1.3.2 abort 失败原因分析 1.1.3.3 disconnect 失败原因分析 1.1....
文件包含了MM7口API,测试工具包,可以进行彩信收发测试
【彩信收发Demo】是基于Android 5.0系统分离出来的一个专门处理彩信(MMS)收发功能的源代码示例。这个Demo旨在帮助开发者理解和实现Android设备上的多媒体消息服务,使得应用程序能够发送和接收包含文本、图片、...
Android开发彩信程序 Android彩信程序是Android系统中的一种彩信服务,允许用户发送彩信。下面是Android开发彩信程序的相关知识点: 1. Android彩信程序的实现 Android彩信程序的实现需要使用到Android系统提供的...
本文将深入探讨Android短信收发的流程,包括发送、接收、处理以及相关的API使用。 一、短信发送流程 1. 用户在短信应用中输入收件人和消息内容。 2. 应用调用`SmsManager`类提供的方法,例如`sendTextMessage()`,...
在Android平台上,发送彩信(Multimedia Messaging Service, MMS)是通过Intent对象来实现的。这个过程涉及到多个步骤,包括构建MMS消息、设置消息内容、指定接收者以及触发发送操作。以下是对如何在Android中实现...
本主题将深入探讨如何在Android应用中实现彩信发送功能,基于源码的角度来解析整个流程。 1. **彩信发送流程** 在Android中,发送彩信主要涉及` MultimediaMessageService` 和 `MMSTransport` 类。首先,你需要...
本文将深入探讨手机彩信的信令流程及其结构,这对于理解移动通信网络的工作原理至关重要。 首先,彩信的架构基于WAP(Wireless Application Protocol)协议栈,包括WDP(Wireless Datagram Protocol)、WTP...
在IT领域,短彩信(Short Message Service, SMS 和 Multimedia Messaging Service, MMS)是通信服务的重要组成部分,特别是在移动设备上。短彩信数据表结构是数据库设计的一部分,用于存储和管理短信和彩信的相关...
在Android平台上,自定义彩信发送是一个常见的需求,特别是在开发具有特定功能的通讯应用时。标题"android 彩信 自定义"表明我们将讨论如何在Android系统中不依赖系统的彩信服务来实现自定义彩信的发送功能。描述...
在Android平台上,开发人员经常需要处理各种数据类型的通信,其中包括短信和彩信。彩信(MMS)是一种比传统短信(SMS)更丰富的通信方式,它允许用户发送文本、图片、音频甚至视频内容。在某些场景下,如验证码、...
在这个压缩包文件中,你可能会找到一些关于如何在编程中实现彩信收发的代码示例。 彩信的发送和接收涉及到多个技术层面,包括网络通信、数据编码、协议解析等。以下是一些可能涵盖的知识点: 1. **MMS协议**:彩信...