博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux下基于bluez与obex的服务端实现流程
阅读量:4037 次
发布时间:2019-05-24

本文共 2110 字,大约阅读时间需要 7 分钟。

Linux下基于bluez与obex的服务端实现流程:

一个服务端需要给对方提供OBEX Object Push服务的通道,所以在打开服务器之前需要确定已经将该服务注册到SDP服务器,Linux下使用sdptool注册该服务的命令为:sdptool add opush;

1.OBEX_Init()用于初始化一个obex instance handle;

arg1:OBEX_TRANS_BLUETOOTH用于声明传输协议为bluetooth;

arg2:callback function;

arg3:flag=OBEX_FL_KEEPSERVER,接收到请求后,服务器可以继续接收其他客户端的请求;

2.OBEX_SetUserData()设置用户自己的变量,该函数的使用完全取决于用户自己;

3.BtOBEX_ServerRegister();一个专用于蓝牙协议的服务端函数,用于监听客户端发送的请求;

该函数内部创建了一个 socket(调用socket(AF_BLUETOOTH, SOCK_STREAM, BTPROTO_RFCOMM)),bind该socket到本地蓝牙地址,将该socket转化为监听sockt,之后该socket才能够监听端口上 来自客户端的连接请求;

4.OBEX_HandleInput()函数用于读取并处理接收到的数据,如果没有数据到达,该函数将会阻塞;

该函数内部调用了selet()函数,向系统登记了参数handle的客户端sockt与服务端sockt,让系统监听socket上的事件,如果是服务端socket上有数据到达,则调用accept()函数为客户端创建一个新的sockt,
如果OBEX_Init()的flag不是设置为OBEX_FL_KEEPSERVER,则关掉服务端socket,禁止其他客户端的连接请求;
(???: accept()为客户端创建一个新的socket,并返回其描述符,那么新创建的socket的端口是重新分配的呢还是原先服务端的channel,如 果重新分配,则只在服务端的channel上注册了服务,如果没有重新分配,那么是多个客户端用同一个channel么o(∩_∩)o...)

5.callback:OBEX_EV_ACCEPTHINT;

6.OBEX_ServerAccept()该函数返回上述客户端的socket;

函数内部重新创建了一个obex instance handle,并将上述服务器handle的参数复制到该handle,获得服务器handle的fd(accept为客户端创建的socket)后,清除服务器本身的fd;
该函数同时也为新创建的obex instance handle设置callback function及Userdata;
至此,已经为客户端创建了一个与服务端完全独立的obex instance handle,此后该服务端的操作都由该handle标识,而服务器的socket则继续监听其他客户端的连接请求;

 

9.callback:OBEX_EV_REQDONE:OBEX_CMD_CONNECT;

10.callback:OBEX_EV_REQHINT一个请求即将到来;

调用OBEX_ObjectSetRsp(object,OBEX_RSP_CONTINUE,OBEX_RSP_SUCCESS)设置响应操作码

11.callback:OBEX_EV_REQCHECK:第一个接收到的请求包已经被解析;

12.callback:OBEX_EV_PROGRESS(收到n个此事件,说明客户端正在传输文件内容);
13.callback:OBEX_EV_REQ :OBEX_CMD_PUT;
OBEX_ObjectSetRsp(object,OBEX_RSP_CONTINUE,OBEX_RSP_SUCCESS)设置响应操作码;
此时,客户端文件传输完毕,需进行处理:
OBEX_ObjectGetNextHeader()分别取得文件的名称与内容;

14.callback:OBEX_EV_REQDONE:OBEX_CMD_PUT;

15.callback:OBEX_EV_REQHINT一个请求即将到来

16.callback:OBEX_EV_REQ::OBEX_CMD_DISCONNECT
OBEX_ObjectSetRsp(object,OBEX_RSP_SUCCESS,OBEX_RSP_SUCCESS)设置响应操作码;

17.callback:OBEX_EV_REQDONE:OBEX_CMD_DISCONNECT;

OBEX_TransportDisconnect(handle)断开连接;
注意:该函数只是将socket关闭,并没有释放handle所占用的资源,所以在应用时需要释放handle占用的资源;

18.OBEX_Cleanup()关掉obex handle并释放该handle占用的资源。

(该函数同样关闭了客户端及服务端socket);

至此,服务器接收客户端的一个事例完成。

转载地址:http://qscdi.baihongyu.com/

你可能感兴趣的文章
[LeetCode By Python]122. Best Time to Buy and Sell Stock II
查看>>
[LeetCode By Python]125. Valid Palindrome
查看>>
[LeetCode By Python]136. Single Number
查看>>
[LeetCode By MYSQL] Combine Two Tables
查看>>
如何打开ipynb文件
查看>>
[Leetcode BY python ]190. Reverse Bits
查看>>
Android下调用收发短信邮件等(转载)
查看>>
Android中电池信息(Battery information)的取得
查看>>
SVN客户端命令详解
查看>>
Android/Linux 内存监视
查看>>
Linux系统信息查看
查看>>
用find命令查找最近修改过的文件
查看>>
Android2.1消息应用(Messaging)源码学习笔记
查看>>
Phone双模修改涉及文件列表
查看>>
android UI小知识点
查看>>
Android之TelephonyManager类的方法详解
查看>>
android raw读取超过1M文件的方法
查看>>
ubuntu下SVN服务器安装配置
查看>>
MPMoviePlayerViewController和MPMoviePlayerController的使用
查看>>
CocoaPods实践之制作篇
查看>>