【Android】【Bluetooth Stack】蓝牙电话本协议分析(超详细)

2024-03-20 10:12

本文主要是介绍【Android】【Bluetooth Stack】蓝牙电话本协议分析(超详细),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 精讲蓝牙协议栈(Bluetooth Stack):SPP/A2DP/AVRCP/HFP/PBAP/IAP2/HID/MAP/OPP/PAN/GATTC/GATTS/HOGP等协议理论
2. 欢迎大家关注和订阅,【蓝牙协议栈】专栏会持续更新中.....敬请期待!

目录

1. 协议简述

1.1 PBAP

1.2 OBEX

2. PBAP协议栈

2.1 vCard格式

2.2 PBAP 角色介绍

2.3 PSE & PCE 功能

2.3.1 Download

2.3.1.1 PullPhonebook Data Format

2.3.1.2 Application Parameters Header

2.3.2 Browsing

2.3.2.1 SetPhonebook Data Format

2.3.2.2 PullvCardListing Data Format

2.3.2.3 PullvCardEntry Data Format

2.3.3 vcf文件


1. 协议简述

        蓝牙电话应用不但需要HFP协议来支持打电话的功能,同时在很多车载蓝牙应用中,都支持查看通讯录和通话记录等信息,而这一部分的所涉及到的协议为PBAP.

 1.1 PBAP

        PBAP(Phone Book Access Profile):电话本访问协议 ,是一种基于OBEX的上层协议,该协议可以同步手机这些具有电话本功能设备上的通讯录和通话记录等信息,用于访问电话本对象(通过 Vcard形式),是基于客户端/服务器的模型,一般是 client从 server端下载电话本。这个协议是为 HFP/SIM协议设计. 

1.2 OBEX

        Object Exchange,对象交换协议,来源与红外通讯协议,但又不局限与具体的传输方式,后来被蓝牙组织SIG吸纳其中部分并进行优化处理作为蓝牙协议中的OBEX层用于蓝牙设备间的文件数据传输,如蓝牙传输文件(OPP)、同步电话簿(PBAP)和同步短信(MAP)等场景下都是以OBEX协议组织相关数据进行传输的;

        OBEX协议有两种角色:Server和Client,通过request-response(请求-响应)形式进行交互,即客户端Client进行请求,服务端Server响应客户端请求的方式传输数据对象;应用于PBAP协议中,Client只能进行数据的读取操作,不能对源数据进行修改,保证了源数据的安全性;

2. PBAP协议栈

 

        PBAP应用层协议处于最上层,之后就是数据格式处理方式,由于通讯录在手机中都是以vCard的格式存储的,所以这边为vCard的数据处理格式。在往下就是通过OBEX协议层联通蓝牙协议栈中的RFCOMM,最后通过统一的数据传输通道L2CAP链路发送数据;

2.1 vCard格式

BEGIN:VCARD\r\n
VERSION:3.0\r\n
N:;胡x;;;\r\n
FN:胡x\r\n
TEL;TYPE=CELL:610xxx\r\n
END:VCARD\r\n

  • BEGIN:VCARD:一组联系人信息开始标志
  • END:VCARD:结束标志
  • VERSION:版本
  • FN:姓名
  • TEL;TYPE=CELL:联系人联系方式

上述的参数为必要的,有些参数是可选项,例如:住址、邮件等信息;

当前vCard的版本有vCard 2.1 和 vCard 3.0 两个版本,所以PSE需要两种数据格式都支持,同步数据时根据PCE请求的哪种格式就以哪种格式封装数据进行传输。但是无论是哪种格式,vCard属性内容字符集使用唯一的字符编码utf-8格式进行编码转换;

2.2 PBAP 角色介绍

协议栈中定义了两种角色:

  • PSE:Phone Book Server Equipment,拥有电话本源数据的设备,作为Server,比如手机;
  • PCE:Phone Book Client Equipment,向PSE端请求电话本源数据的设备,作为Client,例如车机;

因为PBAP协议是基于OBEX协议实现的,那PBAP协议获取数据的方式也是通过request-response形式传输的;

2.3 PSE & PCE 功能

FeatureSupport by the PCESupport by the PSE
DownloadC1M
BrowsingC1M
Database IdentifierC3M
Folder Version CountersOM
vCard SelectingOM
Enhanced Missed CallsOO
X-BT-UCI vCard PropertyOO
X-BT-UID vCard PropertyOO
Referencing ContactsC2C2
Contact Image Default FormatXM
  • C1:至少支持其中一种
  • C2:如果支持' X-BT-UID vCard Property ',则可选,否则不支持不可选
  • C3:如果支持“Folder Version Counters” 或 “X-BT-UID vCard Property”,则必选,否则可选
  • O:可选
  • M:必选,必须支持

我们常使用到的功能为:Download和Browsing;我们分析一下;

2.3.1 Download

        Download功能可以将电话簿对象的全部内容同步到PCE,从而PCE端获取到数据后完全可以通过蓝牙电话等应用程序将数据显示到界面,一样可以达到滚动浏览电话簿信息的目的;

        Download这个功能特别是用于PSE端存储的电话簿容量相对较大,PCE设备通常从PSE端下载这些大容量数据并在其本地存储整个电话簿的场景。

FeatureFunctionSupport by the PCESupport by the PSE
Phone Book Download featurePullPhonebookMM

协议层提供了PullPhonebook函数,这个函数就是用来下载自己感兴趣的电话簿对象;

2.3.1.1 PullPhonebook Data Format

        由于PBAP协议是基于OBEX的,所以PullPhonebook函数顾名思义也是采用request-response这种一问一答的形式传输数据;

请求格式如下:

Field / HeaderNameValueStatus
FieldOpcodeGET(0x03 or 0x83)M
FieldPacket LengthVariesM
HeaderConnection IDVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderNameObject name (*.vcf)M
HeaderType"x-bt/phonebook"M
HeaderApplication Parameters
- PropertySelectorVariesO
- FormatVariesO
- MaxListCountVariesO
- ListStartOffsetVariesO
- ResetNewMissedCallsVariesC3
- vCardSelectorVariesC4
- vCardSelectorOperatorVariesC5
  • Opcode:操作码,可以理解为标识码,和Type参数组合形成了唯一标识;
  • Connection ID:PBAP连接指令中PSE回复的连接ID 号;
  • Name:表明了需要同步哪种数据;
  • Type:对应了Function,基本上每一个Function对应一个Type,除了SetPhonebook Function;
  • Application Parameters:应用设置的参数,PSE的回复数据会根据这些参数来组装回复data数据,其中就包括了PropertySelector、Format、MaxListCount等参数信息;
  • MaxListCount:本次 GET 获取的最大List Count;
  • ListStartOffset:本次 GET 开始的List Offset;

响应格式如下:

Field / HeaderNameValueStatus
FieldResponse0x09 or 0xA0 or Error CodeM
FieldPacket LengthVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderApplication Parameters
- PhonebookSizeVariesC3
- NewMissedCallsVariesC4
- PrimaryFolderVersionVariesC5
- SecondaryFolderVersionVariesC5
- DatabaseIdentifierVariesC6
HeaderBody/End of BodyvCard object(s)C7
  • PhonebookSize:Name个数,当MaxListCount = 0时,返回Name的总个数;
  • NewMissedCalls:新增的未接电话
  • Body/End or Body:请求中MaxListCount != 0时,返回Name对应的数据,回复数据中的vCard对象只应包含使用属性选择器Attribute Selector参数指示的属性,并且应使用格式Format参数指示的格式组装数据;
2.3.1.2 Application Parameters Header

该数据是由一组不同的TAG组成的整体的Application Parameters;

ValueTag IDLengthPossible Values
Order0x011 byte0x00 = indexed 0x01 = alphanumeric 0x02 = phonetic
Search Value0x02variableText
SearchProperty0x031 byte0x00 = Name 0x01 = Number 0x02 = Sound
MaxListCount0x042 bytes0x0000 to 0xFFFF
ListStartOffset0x052 bytes0x0000 to 0xFFFF
PropertySelector0x068 bytes64 bits mask
Format0x071 byte0x00 = 2.1 0x01 = 3.0
PhonebookSize0x082 bytes0x0000 to 0xFFFF
NewMissedCalls0x091 byte0x00 to 0xFF
PrimaryVersionCounter0x0A16 bytes0 to (2 128 – 1)
SecondaryVersionCounter0x0B16 bytes0 to (2 128 – 1)
vCardSelector0x0C8 bytes64 bits mask
DatabaseIdentifier0x0D16 bytes0 to (2 128 – 1)
vCardSelectorOperator0x0E1 byte0x00 = OR 0x01 = AND
ResetNewMissedCalls0x0F1 byte0x01 = Reset
PbapSupportedFeatures0x104 bytesBit 0 = Download Bit 1 = Browsing Bit 2 = Database Identifier Bit 3 = Folder Version Counters Bit 4 = vCard Selecting Bit 5 = Enhanced Missed Calls Bit 6 = X-BT-UCI vCard Property Bit 7 = X-BT-UID vCard Property Bit 8 = Contact Referencing Bit 9 = Default Contact Image Format Bit 10 ~ 31 Reserved 1
  • PropertySelector:用于指示请求的vCard object中应该包含的属性,PSE根据这些属性来组织恢复的Body/End of Body Header中包含的数据,PCE只能使用此Header接收所请求的vCard所需要内容,PSE不得回复任何其他性能数据,除非PCE有其他要求;

        PropertySelector的值是由一个64位的数据组成,所以每一位都代表了一种属性,如果PCE请求的电话簿需要包含对应的数据,就将该数据对应在PropertySelector的二进制位设置为true(1)。具体每一位的含义见下图:

流程图

        这里有一个需要注意的,PCE和PSE的服务连接不是一直保持的,只有在同步Phone Book的时候,服务保持连接,同步完成之后,就会断开;

2.3.2 Browsing

FeatureFunctionSupport by the PCESupport by the PSE
Phone Book Browsing FeatureSetPhonebookMM
PullvCardListingMM
PullvCardEntryMM

  • SetPhonebook:选择感兴趣的Phone Object
  • PullvCardListing:client使用该Function获取感兴趣的Phone Object 列表
  • PullvCardEntry:client使用该Function获取感兴趣的Phone Object(单个)
2.3.2.1 SetPhonebook Data Format

请求格式:

Field / HeaderNameValueStatus
FieldOpcodeSETPATH (0x05)M
FieldPacket LengthVariesM
FieldFlagsUp / Down / RootM
FieldConstantReserved (0)M
HeaderConnection IDVariesM
HeaderNameName of the folderO

响应格式:

Field / HeaderNameValueStatus
FieldResponse Code0xA0 or Error CodeM
FieldPacket Length3M
2.3.2.2 PullvCardListing Data Format

请求格式:

Field / HeaderNameValueStatus
FieldOpcodeGET(0x03 or 0x83)M
FieldPacket LengthVariesM
HeaderConnection IDVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderNameName of the folderM
HeaderType"x-bt/vcard-listing"M
HeaderApplication Parameters
- OrderVariesO
- SearchValueVariesO
- SearchPropertyVariesC3
- MaxListCountVariesO
- ListStartOffsetVariesO
- ResetNewMissedCallsVariesC4
- vCardSelectorVariesC5
- vCardSelectorOperatorVariesC6

响应格式:

Field / HeaderNameValueStatus
FieldResponse Code0x09 or 0xA0 or Error CodeM
FieldPacket LengthVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderApplication Parameters
- PhonebookSizeVariesC3
- NewMissedCallsVariesC4
- PrimaryFolderVersionVariesC5
- SecondaryFolderVersionVariesC5
- DatabaseIdentifierVariesC6
HeaderBody/End of BodyvCard object(s)C7
2.3.2.3 PullvCardEntry Data Format

请求格式:

Field / HeaderNameValueStatus
FieldOpcodeGET(0x03 or 0x83)M
FieldPacket LengthVariesM
HeaderConnection IDVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderNameObject name (*.vcf) or X-BT-UID (X-BT-UID)M
HeaderType"x-bt/vcard"M
HeaderApplication Parameters
- PropertySelectorVariesO
- FormatVariesO

响应格式:

Field / HeaderNameValueStatus
FieldResponse Code0x09 or 0xA0 or Error CodeM
FieldPacket LengthVariesM
HeaderSingle Response Mode0x01C1
HeaderSingle Response Mode Param0x01C2
HeaderApplication Parameters
- DatabaseIdentifierVariesC3
HeaderBody/End of BodyvCard objectC4

 流程图

2.3.3 vcf文件

        Download和Browsing功能描述完成之后,我们需要知道,所有的Phone Object信息都是来自于PSE端,而在PSE端保存Phone Object的方式或者是路径可能有很多;

  • 存储设备

    • 手机:telecom/xxx.vcf
    • SIM卡:SIM1/telecom/xxx.vcf

        无论是哪种存储方式,其对应都有相同的数据存储类型,例如通讯录、通讯记录,而在通讯记录中,又可以分为:来电、去电、未接来电、所有通讯记录。同时电话簿还提供了两个功能:快速拨号和收藏联系人;

上述描述的分类方式,对应了PSE端存储文件格式;

Phone ObjectASFormatDesc
Phone Book Objectpbpb.vcf通讯录
Incoming Calls History Objectichich.vcf来电通话记录
Outgoing Calls History Objectochoch.vcf去电通话记录
Missed Calls History Objectmchmch.vcf未接来电通话记录
Commbined Calls History Objectcchcch.vcf所有的通话记录
Speed-Dial Objectspdspd.vcf快速拨号
Favorite Contacts Objectfavfav.vcf收藏通讯录

这篇关于【Android】【Bluetooth Stack】蓝牙电话本协议分析(超详细)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/829129

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

在macOS上安装jenv管理JDK版本的详细步骤

《在macOS上安装jenv管理JDK版本的详细步骤》jEnv是一个命令行工具,正如它的官网所宣称的那样,它是来让你忘记怎么配置JAVA_HOME环境变量的神队友,:本文主要介绍在macOS上安装... 目录前言安装 jenv添加 JDK 版本到 jenv切换 JDK 版本总结前言China编程在开发 Java