Android Bluetooth OPP的理解与使用之二

问题点3Bluetooth OPP Server层的入口类是哪个?

---其核心类是:BluetoothOppService;

问题点4:Bluetooth OPP是如何完成init注册动作的?

OPP 因其没有在Framework层提供接口,所以其init动作并不是由

BluetoothAdapter.java的方法getProfileProxy实现;

由实际Log Tracing发现:OPPServer初始化通过接收BT on广播实现,但需理解的是:在执行OPP init启动监听BT状态前,BluetoothOppService已启动,具体体现在其start方法已经被执行,然后才是监听;

实际Tracing

-->在BluetoothOppService中,BluetoothAdapter.ACTION_STATE_CHANGED”

当收到BT on后,除了执行startListener动作外,还启动了一个名为

“BluetoothDevicePicker.ACTION_LAUNCH”APK

-->执行私有方法startListener,在方法内发出Message START_LISTENER

-->在Message中,执行startSocketListener

-->方法startSocketListener中,使用到了ObexServerSockets的相关方法;

核心实现是:ObexServerSockets.createInsecure:创建监听socket

并调用” sdpManager.createOppOpsRecord”进行SDP注册;

 

 

以上设置了L2CAP PSM值、OPP版本为1.2,

同时设置了object format “SUPPORTED_OPP_FORMAT”

Notechecking 发现MAP等都是使用ObexServerSockets进行的socket创建;

/**************************************************/

延伸问题点:不论OPP还是MAP等,其使用“ObexServerSockets.createInsecure(this)”时都没有指定其channel;

  Checking 发现其在SDP注册时使用了createInsecure返回的RFCOMM channel值,使其两者关联起来;

 /**************************************************/

-->调用SdpManager.java中的方法createOppOpsRecord

这里注意的是:最后调用了com_android_bluetooth_sdp.cpp (packages\apps\Bluetooth\jni)中的JNI 方法:sdpCreateOppOpsRecordNative;

所以:OPP Server的注册部分,其实并没有直接像SPP 一样直接调用BluetoothSocket进行监听;

但需留意:BluetoothOppService本身implementsIObexConnectionHandler

 

 

问题点5Bluetooth OPP的服务类BluetoothOppService是如何被启动的?

通过Log Tracing 发现, 其是通过setProfileServiceState 启动的;

具体flow是:

-->AdapterService.java中的方法startCoreServices中,执行setProfileServiceState

(startCoreServices-----这是Android 8中的API定义,在910API名称已经修改为

startProfileServices,但log还是"startCoreServices()")

-->setProfileServiceState中执行startService启动OPP Profile服务(其他profile Server也是在此启动);

Note : Native BT中对Profile的启动和关闭,

Config.java (packages\apps\Bluetooth\src\com\android\bluetooth\btservice)决定;

问题点6BluetoothOppProvider的详细介绍;

Note需要关注ContentProvider的权限:读权限和写权限,如果当前操作不符合权限,将返回异常;

同时需要注意android:authorities属性所指定的值,这个值可以理解为对具体

ContentProvider使用,因每个具体ContentProvider 实现类都将通过android:authorities属性来设置其xxx,外部应用将通过Uri.parse(““content://xxx””);形式来访问ContentProvider,而不是直接使用ContentProvider子类申请对象形式操作;

 注意:BluetoothOppFileProviderBluetoothOppProvider的区别;

所以也正因不会执行调用ContentProvider子类对象,所以我们在Android 8中并没有看到外部应用如何调用BluetoothOppProvider,以下是整个Android 8 Source Code搜索结果,我们能在BluetoothShare.java中看到其URL的定义:

 以上的第二部分是具体的分表“btopp”

 所以BluetoothOppProvider的具体使用,表现为“BluetoothShare.CONTENT_URI”

BluetoothOppProvider中也有通过“addURI”进行url分表的绑定;当前定义了两个表"btopp" “btopp/#”; 可以使用UriMatcheraddURI方法将UriUri_Code关联到一起。这样,当外界请求访问时,就可以根据请求的Uri来得到Uri_Code,有了Uri_Code我们就可以知道外界想要访问哪个表,然后就可以进行相应的数据操作。

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值