zoukankan      html  css  js  c++  java
  • OpenOBEX代码阅读笔记

    OpenOBEX代码阅读笔记

     

    转载时请注明出处和作者联系方式:http://blog.csdn.net/absurd

    作者联系方式:Li XianJing <xianjimli at hotmail dot com>

    更新时间:2007-1-20

     

    OBEX是Object Exchang的简称本来是IrDA™为红外传输制定的协议但它并不限于特定的底层传输方式,可以运行于blueteethusbtcp/ip其它多种协议之上。OBEX主要是会话层协议,同时也包括应用层部分功能。它可以传输任何对象,在手机中通常用来传输文件、图片、名片(Vcard)和日程(Vcal)等。OpenOBEX是一套开放源代码的OBEX协议实现,提供clientserver两端的功能,本文简要介绍一下OBEXOpenOBEX

     

    运行于irDA(红外协议)之上的OBEX协议栈:

     

    IrLAP 是数据链路层协议。

    IrLMP 是多路复用协议。.

    Tiny TP 提供流控。

    IAS 是Information Access Service。

     

    红外的协议栈看起来挺复杂的,所幸linux kernel里已经实现了这些协议,在用户空间调用非常简单,和使用普通socket几乎完全一样。在irobex.c中,我们可以看到,在创建socket时把family设置AF_IRDA为就OK了,地址是个字符串。

     

    运行于bluetooth(蓝牙协议)之上的OBEX协议栈:

     

    Baseband、LMP和L2CAP 是蓝牙对应于OSI物理层和数据链路层协议。

    RFCOMM是GSM TS 07.10是蓝牙适配层协议。

    SDP 是蓝牙服务发现协议。

     

    和红外协议栈一样, linux kernel里已经实现了Bluetooth协议,在用户空间调用非常简单,和使用普通socket几乎完全一样。在btobex.c中,我们可以看到,在创建socket时把family设置AF_BLUETOOTH为就OK了。

     

    OBEX的原语:

     

    1.       CONNECT:客户端发起连接请求,服务端如果接受连接请求,就返回正确的CONNECT Response。

     

    2.       PUT/GET:一旦连接建立后,就可以用PUT传输数据,服务器端要响应PUT,以标识请求的成功或失败。或者用GET获取数据,服务器端要响应GET,以传回客户端所要的数据。

     

    3.       ABORT:取消前面的未完成的操作。

     

    4.       DISCONNECT:用于传输完毕或出错时断开连接。

     

    OpenOBEX的代码说明:

    1.       obex_connect.c/.h:处理CONNECT PDU,打包和解包。

    2.       obex_header.c/.h:PDU处理的公共函数及数据类型定义。

    3.       obex_object.c/.h:对象处理函数,客户端和服务器公用代码。

    4.       obex_server.c/.h:服务器端处理代码。

    5.       obex_client.c/.h:客户端处理代码。

    6.       obex_transport.c/.h:传输接口的抽象。

    7.       irobex.c/.h基于红外的传输方式。

    8.       usbobex.c/.h:基于USB的传输方式。

    9.       inobex.c/.h:基于TCP/IP的传输方式。

    10.    btobex.c/.h:基于蓝牙的传输方式。

     

    对于OBEX,我也是新手,还在继续研究,若有新的发现,我会及时补充。也请各位高手不吝赐教。

     

    参考资料:

    syncml_obex_v10_20001207.pdf

    OpenOBEX: http://openobex.triq.net/

     

    ~~end~~

     

     

  • 相关阅读:
    母版页中对控件ID的处理
    使用Gridview绑定数据库中的图片
    导出Excel表格时,如何把数据库表中的编号转换成配置文件中的"汉字"
    ORA01502: 索引'P_ABCD.PK_WEB_BASE'或这类索引的分区处于不可用状态
    Oracle 把触发器说透
    规模估算失准 软件开发成空中楼阁
    在web开发中的三个层次使用事务
    oninput,onpropertychange,onchange的用法和区别
    Oracle 把游标说透
    在datatable中,在指定位置插入列
  • 原文地址:https://www.cnblogs.com/zhangyunlin/p/6167759.html
Copyright © 2011-2022 走看看