十二章Comms和消息传送.ppt
《十二章Comms和消息传送.ppt》由会员分享,可在线阅读,更多相关《十二章Comms和消息传送.ppt(78页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、IC-MSP V1.0十二章Comms和消息传送 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望完成本章内容之后我们将能够:掌握Symbian OS 的通讯架构了解多媒体短信业务(MMS)本本 章章 目目 标标2 本章概述了Symbian OS提供的comms工具,并详细研究了用于消息传送,特别是用于发送和接收多媒体消息(MMS)的API。3概述 Symbian OS上的comms开发可从3个主要方面考虑:l开发与通信硬件(比如串口或电话硬件)对话的驱动程序。这一
2、类型的开发在手机生产时由手机开发商承担。Symbian提供与某些特定的基准硬件(如Intel Lubbock板)一起工作的驱动程序,它可用于开发其中的真正手机硬件和驱动程序。l开发协议实现,如用于访问Web的HTTP实现,或用于红外线协议的红外线。手机开发者和第三方可以开发协议实现,并扩充到Symbian OS已经提供的部分中。4概述l开发使用有效协议的应用程序:手机开发者提供具有基本通信应用程序的手机,如电话和消息传送等应用程序。不过,很多领域中的应用程序可以受益于与通信的集成,其中包括游戏它可以通过多玩家通过本地通信协议(如蓝牙)或通过2.5G电话网络上的包数据进行比赛,从而实现交互。企业
3、应用与专用应用程序服务器通信。5概述通信组通信组目前可用的通信组件包括:l串行通信框架。l套接字框架。l电话框架。lTCP/IP栈。l蓝牙栈。l红外线栈。lSMS和EMS栈。6概述lWAP栈。lHTTP传输框架。lTelnet和FTP引擎。l消息协议支持,包括MMS、SMTP、POP3和IMAP4。这些组件提供了应用程序可访问的API。7概述CommsComms及平台及平台 如同其他领域的Symbian OS开发,在进行comms相关的工作时,需要了解什么是Symbian OS提供的,什么是UI平台增加的,比如Series 60和UIQ。基本原则是:Symbian OS提供实现特定通信协议的引
4、擎组件,并向这些引擎公布API;UI平台提供使用这些引擎的应用程序。例如,Symbian OS提供了实现因特网电子邮件协议的组件,而UIQ和Series 60提供允许用户发送和接收电子邮件的消息传送应用程序。8OS Comms架构要理解Symbian OS的comms,需要理解所提供通用框架和插入这些框架的特定协议的实现。本节首先从框架着手。每种关键框架都使用了Symbian OS的客户端服务器架构。在这种架构中,后台运行的程序(服务器)为其他多个程序(客户)提供服务。当手机上的多个客户程序需要访问一些公共资源时,会选择这种方案。服务器的任务是控制对资源的访问。对于底层的comms服务器,所讨
5、论的资源可能是一个硬件资源,比如串口。资源也可以是共享的数据,比如消息的存储。9 尽管框架通常具有服务器本身之外的其他要素,如实用工具类的库,但提到整个框架时,通常还是简称为服务器。某些情况下,API使得客户端服务器架构的运用变得显而易见。例如,使用电话功能时,基本的任务就是创建一个RTelServer对象,它提供与电话服务器的初始连接(Symbian OS约定就是和RTelServer类似的API类,它用于访问以R开头的服务器)。如消息等其他API,提供广泛的客户端类,从客户程序中隐藏了客户端服务器接口的直接使用。OS Comms架构10 核心服务器如下:l套接字:利用TCP/IP等协议,提
6、供可寻址端点之间的通信。自Symbian OS的第一版起,即成为它的一部分,7.0增加了一个新的API,用于创建和管理连接。l串行comms:提供简单串行连接之上的通信,如用于处理RS232。l消息传送:利用因特网电于邮件和SMS这类协议,提供消息的发送、检索和存储。l电话:提供电话呼叫及服务的控制,以及对电话功能配置的控制。OS Comms架构11套接字套接字 套接字的概念首次出现于加州大学伯克利分校的Unix伯克利软件发行中心(BSD),它是以C语言写的一个API。自此之后,套接字常见于很多操作系统和语言中。套接字代表一个通信“信道”的逻辑端点。它是物理机器的网络地址和逻辑端口号的组合,另
7、一个套接字可以给它传输数据。因为套接字由机器地址和端口号确定,所以在一个特定的计算机网络中,每个套接字是惟一标识的。这就允许应用程序惟一地识别网络中与其通信的另一位置。OS Comms架构12 套接字通常用于在运行因特网协议(IP)的网络上进行通信。这时机器地址就是一个IP地址,端口将指定一些因特网应用程序,如Web或FTP。与其他操作系统的套接字相比,Symbian OS实现的套接字有两个主要不同:l套接字可用于访问多种协议,而不仅访问TCP/IP。其中包括蓝牙协议L2CAP和 RFCOMM,以及红外线协议IrDA、IrTinyTP和IrMUX。lAPI用C+编写,与传统的BSD C API
8、不同。如果考虑必须使用C API,例如向其他操作系统移植代码时,可以考虑Symbian OS的C标准库(STDLIB)实现中可使用的C API。OS Comms架构13 用于套接字的Symbian OS C+API是套接字客户API,发布在头文件es_sock.h和库文件esock.dll中。与套接字服务器的客户接口由RSocketServ提供,套接字本身由RSocket封装。套接字的客户API异步调用套接字服务器,它协调客户端访问套接字服务,并管理与协议模块的通信,这些协议模块提供了对特定网络协议的支持。协议模块是插件DLL,服务器根据需要进行加载和卸载。OS Comms架构14 除与套接字
9、连接,并读写数据外,API还提供了对其他工具的访问:l主机名解析(RHostResolver):一些网络类型能够在适合于给最终用户显示的符号主机地址与协议内部使用的数字地址之间转换。在TCP/IP中,主机名解析服务就是域名服务(DNS)。对于蓝牙和红外线,解析接口可用于发现其他哪些设备在范围内,并可使用这些协议进行通信。通过RHostResolver对象产生的查询打包在TNameEntry描述符中,它保存了包含主机名和地址的TNameRecord对象。OS Comms架构15l协议信息(TProtocolDesc):可以查询手机上支持哪些套接字协议,并可以得到每个协议的信息,比如协议名称和用于
10、表明其性能的标志。l套接字API还提供了下述功能,它们可能用得比较少:l网络数据库访问(RNetDatabase):用于访问关于设备的数据库。对于红外线,存在IrDA信息访问服务(IAS)这种服务。它与TCP/IP或蓝牙没有关联。l服务解析(RServiceResolver):用于查询远程设备的性能,也就是说,该设备在相应的协议上可以提供什么服务。它不是为了TCP/IP、蓝牙或红外线而实现的。蓝牙标准中有种服务,即蓝牙业务搜寻协议(SDP),但是Symbian OS蓝牙设备没有为此使用套接字API,因为它有自己专门的SDP API。OS Comms架构16 在Symbian OS V7.0s以
11、前的版本中,如何构建网络连接以实现套接字请求,套接字客户API的调用者不必关心。连接是隐式建立的,举例如下。例如,应用程序请求与某个远程地址的TCP套接字。与管理网络接口(NIFMAN)相关的Symbian OS组件检查没有已存在的网络连接。它就读取通信设置项数据库(CommDb),了解怎样建立连接。例如,设置项可以指定拨号连接到某个服务提供商(ISP)。调用能够完成拨号的其他组件,并利用适当的协议(如PPP)连接到ISP。建立连接的所需设置,如ISP的电话号码和登录信息,也保存在通信数据库中。OS Comms架构17 诸如W-CDMA和最新版本的GPRS等技术都可以在一个连接中建立多个子连接
12、。这在v7.0s中是由连接管理接口RConnection来支持的。它向客户提供创建、配置和监视连接与子连接的功能。OS Comms架构18串行通信串行通信 串行通信比套接字要简单一些。数据从手机的一个端口简单地写入和读取,而不需要连接许多可能的设备及其服务。习惯上,当Symbian OS设备通过一根电缆或红外线连接到PC进行同步,或连接到外部调制解调器,此时使用这种方式。与套接字类似,Symbian OS串行comms的实现使用了一个服务器,它可以加载插件模块来处理特定的通信协议。这些插件模块称做CSY模块,它们被串行通信服务器加载,客户应用程序不能直接访问。OS Comms架构19 Symb
13、ian OS手机可能包括许多CSY模块作为标准配置,比如用于处理RS232和红外线串口通信的模块。串口协议模块API允许开发新的CSY模块。通过服务器会话类RCommServ,可以找到手机上可用的串口以及它们的协议。一旦选定了要用的端口,就可以通过串口接口RComm访问它。该类用于读、写、配置、设置中断条件和得到端口状态信息。OS Comms架构20 通常,使用端口前,要先设置其配置。这包括设置数据速率、奇偶类型和握手控制等。这些设置保存在一个TCommConfigV01类型的串口配置块中。在配置串口前,可以先检查它的性能,以保证所需配置是可行的。该串口的性能由一个TCommCapsV01类型
14、的对象进行封装。OS Comms架构21消息传送消息传送 Symbian OS的消息传送组件为多协议消息传送提供了一个框架,并且支持特定的消息传送协议。消息传送为建立高性能消息客户应用程序以及创建用于支持个别消息传送协议的插件模块提供了可能。建立这种插件模块的组件集合叫做消息类型模块(MTM)。与底层通信协议(如TCP/IP)的所有交互均由MTM完成。OS Comms架构22 消息传送架构提供了一些基类,这些基类定义了用于MTM实现的组件接口。利用基类按口,允许客户应用程序发现并动态使用可用的消息传送协议。协议提供者为他们的MTM实现开发新库。这些实现在协议需要时访问底层通信库。OS Comm
15、s架构23消息服务器消息服务器 消息服务器控制对消息数据的访问,并将协议相关的请求委托给服务器端MTM。由服务器保存的每条消息部有一个TMsvId类型的整型标识符。一条消息的状态(例如是否可读或不可读)和一些常规属性对大多数消息是公用的,如日期和主题保存在头部数据对象中,需要通过TMsvEntry类访问。消息还可以具有:l一个文件存储:保存消息正文文本、协议相关的数据:它由CMsvStore类封装。l一个目录:可存放相关文件(如消息附件)OS Comms架构24 总体上,消息从ID、头部、存储和文件目录,都可以访问和操作,并由CMsvEntry封装。除消息本身之外,服务器还保存代表服务和文件夹
16、的记录。一个服务就是一个收集设置信息的有用抽象。例如SMTP,服务将为邮件帐户指定设置。文件夹保存记录组(消息和其他文件夹)。其中某些文件夹,如收件箱和草稿箱,总是存在并且在消息服务器首次启动时创建。用户也可以创建自己的文件夹。消息以树形结构保存,与文件系统的目录树形式类似。树中的每条记录代表一个服务、消息文件夹或消息部分。图8-1给出了一个实例。OS Comms架构25OS Comms架构图8-1 消息存储26树可以分解为三级:l根记录:只是用来表示将树结构捆绑在一起。l服务记录:有一个本地服务,在它下面保存文件夹和消息,还有零或多个远程服务。远程服务代表消息账号。l消息和文件夹记录:本地服
17、务下的消息和文件夹代表存储在设备上的消息。远程服务下的消息和文件夹代表远程服务器上存在的消息在本地的副本。例如,在POP3电子邮件服务下面,会有POP3电子邮件服务器上存在的所有消息的副本;而在SMS服务下面,可以找到SIM上保存的SMS消息。OS Comms架构27MTMMTM基类基类 MTM基类是提供消息传送协议支持的子类,可以认为有四个类。用户接口MTM(CBaseMtmUi)提供用户接口操作,其中包括:l创建:运行消息编辑器并打开一条新消息。l编辑:如果记录是一条消息,则装入编辑器;如果记录是一个服务,则编辑设置。l浏览:为消息运行浏览器。l显示操作的进度。OS Comms架构28 客
18、户端MTM(CBaseMtm)提供一个通用接口来操作消息数据。该类定义的函数可以用于:l创建消息。l回复消息。l转发消息。l增加删除地址。l增加删除正文文本。l增加删除主题。l增加删除附件。OS Comms架构29 UI数据MTM(CBaseMtmUiData)提供对特定UI MTM相关资源的访问。它包括:l用于消息服务器记录的MTM相关图标。l用于MTM相关操作的用户界面文字,例如菜单。l信息函数,用于检查MTM函数是否适用于某条记录。OS Comms架构30 最后,服务器端MTM(CBaseServerMtm)提供了通过相关通信协议对远程服务的消息传输,它的功能包括:l移动或拷贝当前处于远
19、程服务下的记录。l从本地服务移动或拷贝到远程服务下的一个目的地。l创建、删除或修改远程记录(如果协议允许操作远程服务器上的消息)。l实现MTM相关命令。例如,同步化记录与远程服务器上消息的命令。OS Comms架构31注册注册 MTM必须用消息服务器注册。这就允许客户查询当前是什么类型的MTM,服务器可以知道哪些DLL要加载,以创建一个给定的MTM组件。通过为每个MTM提供一个资源文件来完成注册。注册类允许标识和实例化MTM组件。关键的类是CClientMtmRegistry和CmtmUiDataRegistry。OS Comms架构32SendAsSendAs 该接口的使用很简单,它允许应用
20、程序创建发出的消息。注意,并不是像接口的名字的含义那样,SendAs提供的API只能创建而不能发送消息。使用SendAs时,它首先向调用者提供一个所有支持发送消息的已注册MTM列表。然后,应用程序可以对MTM列表增加更多的限制:例如,可以要求MTM支持附件或确定的消息大小。SendAs按这些附加的条件查询每一个MTM,并从列表中移除那些与条件不匹配的MTM。应用程序完成条件的增加之后,选择留在列表中的一个MTM,并用它构建消息、添加地址、标题、正文文本和附件。OS Comms架构33 基本接口由CSendAs和MSendAsObserver提供。但是,还存在“引擎”API,它们不为创建和发送消
21、息提供可以简单添加到应用程序中的用户接口。不过,用户接口平台确实提供了包装器类来达到这一目的,它们是:lUIQ API:CqikSendAsDialog。lSeries 60 API:CsendAppUi。OS Comms架构34规划发送规划发送 规划发送功能为客户提供了能够将消息发送安排在稍后某一时刻,而不是立即发送。它允许为规划消息、删除规划、重新规划和核对规划。它还提供针对性的状态信息,如消息目前是否已规划、正在发送或失败等。MTM可以选择是否为规划提供支持。要支持规划,服务器MTM必须派生于CscheduleBase ServerMtm。服务器MTM使用另一个叫做任务规划器的Symbi
22、an OS组件,它可以负责在指定时刻启动指定的动作。与任务规划器的接口由CMsvScheduleSend封装。OS Comms架构35电话电话 移动电话是一个包含很多用于手机服务、网络和硬件标准的复杂领域。Symbian OS提供的电话API及其框架希望通过提供与手机功能的公共接口来减少这种复杂性,而不必关心下层硬件或网络。电话API使用Symbian OS客户端朋艮务器框架,并提供向电话服务器发送请求的R类。服务器反过来将请求传递给管理物理设备的适当电话驱动器插件。OS Comms架构36 手机制造商利用电话API提供手机上的电话应用程序,使用户能够拨打电话及设置服务选项。除了这个用途,电话
23、API可认为是低层次的,主要用于其他更高级的comms组件。例如,套接字一节讲述了要求连接套接字的应用程序请求如何最终拨号连接到ISP。如果确实需要从应用程序中直接使用电话,你会发现一个难题:授权商通常选择在他们的SDK中不暴露过多的高级电话API。所以,除非你是授权商或Symbian的合作伙伴,否则应用程序有可能不能访问所有的手机电话功能。OS Comms架构37 然而,SDK确实暴露了两个应用程序编程者通常感兴趣的API:ETel Core和Third PartyTelephony。ETel Core定义了一组几乎所有电话设备和服务都支持的核心函数。应用程序可以直接使用它来访问通用电话设备
24、。该API可细分为四个主要的类,它们分别封装了与电话服务器、手机、线路和呼叫的会话。l会话类RTelServer:提供了对系统电话信息的访问,特别是可用的手机和TSY。l手机类RPhone:对特定的电话设备进行抽象化。它允许客户访问设备的状态和功能,并在它们改变时得到通知。OS Comms架构38l线路类RLine:代表属于手机的一条线路。客户可以访问线路的状态和功能,并在它们改变时得到通知。l最后,线路可以有零或多个激活的呼叫,呼叫由RCall类进行封装。呼叫具有拨号、等待呼入以及挂机等功能。前面一样,客户可以取得状态和功能的信息,并在它们改变时得到通知。OS Comms架构39 可见,ET
25、el Core具有相当直接和合理的结构,而它的功能封装却比较简单。Third Party Telephony API也是如此,它为电话数据呼叫提供了一个高级接口。它允许此API用户发出电话呼叫、等待呼入或检查线路状态。此API有单独一个类CTelephony。调用者将一个RComm(串口)对象传递给CTelephony对象,当呼叫建立后,它利用该对象读写连接上的数据。OS Comms架构40高级高级APIAPI 现代移动电话标准提供的功能远不止接打电话。Symbian OS对基本ETel Core API提供了扩展,以支持对这些高级性能的使用。不过,如前所述,这些扩展在SDK中可能不提供。主要
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 十二 Comms 消息 传送
限制150内