【经典蓝牙 SSP协议介绍】

2023-12-05

协议定义:

SSP(Secure Simple Pairing):安全简单配对

协议目的:

1、为用户简化配对过程

2、维护或提高蓝牙无线技术的安全性(安全性指两点目标:1、被动窃听保护 2、中间人(MITM)攻击保护

协议流程:

下面说下我认为的SSP协议主要流程(1,2是SSP协议的前期工作,3~6是SSP协议主要工作)

1、Enable Secure Simple Pairing :使能SSP配对

2、L2CAP Connection Request For a Secure Service : L2CAP连接请求一个安全服务

3、IO capabilities exchange : 交换对方的特性,用于后面Authentication stage 1使用哪种算法

4、Public key exchange : 交换交换椭圆曲线的公钥

5、 Authentication stage 1 : 根据IO capabilities exchange进行身份认证

6、 Authentication stage 2 : 使用ECDH Key校验

Enable Secure Simple Pairing

设备必须使用HCI_Write_Simple_Pairing_Mode命令使能SSP。

v2-da21bfe47594fbb7e09c08b865c36bfc_1440w.webp

L2CAP connection request for a secure service

SSP使能后会触发一个L2CAP连接请求一个安全服务(认证和加密的服务),为了启动SSP

v2-269107f618d7799907a34c7c520f07c4_1440w.webp

IO capabilities exchange

蓝牙配对需要交换本机和目标机的IO功能交换,

在SSP的过程中,有两个角色:“Initiator ”和“Responder ”,他们是如何确认的呢?主动发起 IO capabilities exchange流程的那一方就是Initiator,而另一方就是Responder 。

Input功能:

v2-fcacd97b9ffc3f761eab9a691fea74e6_1440w.webp

output 功能:

v2-b2b3c213b02582760dae9040f3b31f00_1440w.webp

将input功能和output能力整合到一起总共有6种组合方式:

将input功能和output能力整合到一起总共有6种组合方式:

v2-0824627a1c59ac2c19aeb33fe0dc2566_1440w.webp

NoInputNoOutput 设备没有输入和输出的能力

DisplayOnly 设备只有输出显示的能力

NoplayOnly 因为没有一个配对算法可以通过yes和no出入,而且设备不支持输出,所以设备的IO能力定义为没有输入和输出

DisplayYesNo 设备只有Yes和No的能力,能够显示

KeyboardOnly 设备可以输入0-9,确认键和Yes和No

上述的IO能力决定了后续的认证方式也就是SSP第三阶段Authentication stage 1。

下面的图是BT Core文档里的

v2-d977ba16a564f61e29ce4951b0dfacad_1440w.webp

Public key exchange

下一步就是交换的public key其实设备自己生成的,还有一个screct key,这两者组成一对key。从上图可以看出,当得到了对方了public key之后就进行了DHKey的计算,DHKey最终会参与到link key的计算当中。

v2-a12320e8fee8c6de9a008fe79ef7c745_1440w.webp

Authentication stage 1

认证有四种算法。算法的选择依据前面所说的IO能力六种组合而定

1、Just Works

2、Numeric comparison

3、Passkey entry

4、 Out of band

第四种了解即可基本用不到这里不做讲解,主要是前两种用的较多,首先来看看 Just Works

适用场景

当一方设备有output的能力,但是另一方设备是no input or output的时候,主要用于没有显示和输入功能的设备,如耳机,音箱等

接下来看 这一阶段的另一个认证方式 Numeric Comparison

适用场景

当双方的设备都有output的能力的时候,双方生成随机数并计算出一个6位数字进行比对确认,比如两个手机进行配对,这个时候两只手机的界面需要用户去确认的。

接下来看 这一阶段的另一个认证方式 Passkey Entry Authentication

适用场景:

主要用于一方有显示功能另外一方有输入功能的场景,典型应用场景就是键盘和TV的配对。

Authentication stage 2

也就是SSP最后的阶段,这一阶段主要的工作就是DHKey的检查验证

v2-51fcbefa02b50765256ef2d839c17d01_1440w.webp

一旦身份通过了认证,DHKey计算就完成了,完成后就检查。这里需要说明一下的是 DHKey是在前面进行public key交换之后就生成了。

这些流程代表SSP完成了,之后的流程就是要生成link key了,Link key从DHKey中计算生成出来,这个link key标志着配对完成。之后只要两者没有删除link key,还是可以回连的。回连的流程就不会再走一系列的生成link key的动作,而是直接验证link key。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【经典蓝牙 SSP协议介绍】 的相关文章

  • iOS Swift - 使用蓝牙外部扬声器时音质较差

    我正在使用从 url 广播应用程序 流式传输的 iOS 应用程序 一旦我尝试通过外部扬声器或汽车音响系统等蓝牙设备从应用程序进行流传输 音频质量就会非常差且刺耳 当从 iOS 设备本身播放时 一切听起来都很好 扬声器和耳机 override
  • iOS - iOS 设备和外部配件 (BluetoothWatch) 之间 BLE 数据传输的 MTU 大小

    我正在为使用 BLE CoreBluetooth 的蓝牙手表开发 iOS 应用程序 Objective C 并且我的手表具有 GATT 蓝牙配置文件 iOS 应用程序最低支持来自 iOS7 我想知道如何使用 Core Bluetooth 框
  • 使用蓝牙调用应用程序

    我们可以使用蓝牙从一个 Android 设备中调用另一台 Android 设备中的应用程序吗 如果可以的话流程是什么 不 您不能从一个 Android 设备调用另一个应用程序 除非两个应用程序都使用蓝牙权限并进行配置
  • Android/iOS 上的相机远程快门如何工作?

    我最近在 Android iOS 上遇到了一个使用蓝牙的内置相机应用程序的远程快门 这是我找到的产品的示例链接 Link http www youtube com watch v cyVG76HDvh4 不是来打广告的 只是简单了解背后的技
  • 在 Android 4.2.2 和 4.3 上关闭 BluetoothSocket 时出现致命信号 11 SIGSEGV

    我的应用程序在 Android 2 3 3 到 4 1 2 下运行良好 但自从 Android 4 2 2 和 Android 4 3 以来 我有一个 fatal signal 11 SIGSEGV at 0x00 当我关闭蓝牙插座时 我查
  • 如何使 Raspberry Pi 3 可被 iOS 和 CoreBluetooth 发现?

    我有一个 Raspberry Pi 3 我正在尝试使其可供 iOS 设备发现 我跑了sudo hciconfig hci0 piscan让它被发现 我可以用我的 iMac 看到它 在 iOS 上 我使用 CoreBluetooth 并扫描附
  • 如何在 Mac OS X 10.9.5 上以编程方式读取低功耗蓝牙传输的数据?

    我正在尝试阅读蓝牙低功耗 http www bluetooth com Pages low energy tech info aspx使用 Ruby 以编程方式传输数据 低功耗蓝牙技术不支持标准规范 v4 0 中的串行端口配置文件 SPP
  • 使用Web蓝牙API时找不到移动设备

    我正在学习 Web 蓝牙 API 使用 google 开发控制台 我无法找到我的移动设备 还尝试了 github 上提供的演示 https github com WebBluetoothCG demos https github com W
  • Android Lollipop BLE 扫描 - 获取没有重复的外设

    Android Lollipop 引入了一种扫描 BLE 外设的新方法 通过蓝牙扫描仪 http developer android com reference android bluetooth le BluetoothLeScanner
  • 在 Android 中通过蓝牙接收音频

    我想创建一个能够接收音频流的 Android 应用程序 我想过使用 A2DP 配置文件 但似乎 Android 不支持 A2DP 接收器 看起来有很多人正在寻找这个问题的解决方案 但是接收普通的比特流 然后在应用程序中将数据转换为音频呢 我
  • 使用 iPhone 控制蓝牙音频设备

    我正在寻找为 iPhone 编写应用程序 它将能够控制汽车中的收音机和 CD 播放器 收音机和播放器具有可用的蓝牙连接 我开始这个问题是为了获得这个地方所需的所有信息 我有几个问题 但如果您发现任何我没有要求的对我开始开发此应用程序不重要的
  • Android蓝牙java.io.IOException:bt套接字已关闭,读取返回:-1

    我正在尝试编写一个代码 仅连接到运行 Android 5 0 KitKat 的设备上的 目前 唯一配对的设备 无论我尝试了多少方法 我仍然会收到此错误 这是我尝试过的最后一个代码 它似乎完成了我看到人们报告为成功的所有事情 有人能指出我做错
  • React Native 模块中的 EADemo 永远不会收到委托方法handleEvent NSStreamEventOpenCompleted?

    我希望我有一个反应本机桥接模块 https facebook github io react native docs native modules ios html 线程 委托或生命周期问题 我不明白这些问题正在阻止接收委托方法调用 我需要
  • 即使提供了通知,也无法在前台服务中运行蓝牙扫描超过 10 - 15 秒

    即使应用程序关闭 我也使用服务来保留对 Android 手机的扫描 我使用广播接收器在被杀死时重新启动我的服务 它会重新启动扫描 并且只工作大约 15 秒 然后停止 当我单击 MainActivity 中的 button1 时 我启动了服务
  • 如何将十六进制数组转换为 UIImage?

    有几个与使用 P25mi 动态打印图像相关的未解答问题 没有一个得到公认的答案 下面有几个链接 如何将图像转换为位图代码以便在 iPhone 中进行蓝牙打印 https stackoverflow com questions 1383828
  • 使用 hcitool 扫描低功耗蓝牙?

    当我运行此命令时 BLE 设备扫描仅持续 5 秒 sudo timeout 5s hcitool i hci0 lescan 输出显示在终端屏幕中 但是 当我将输出重定向到文件以保存广告设备的地址时 每次运行该命令时 我都会发现该文件是空的
  • 通过蓝牙耳机 VoIP 接听电话

    我正在开发 VoIP Android 应用程序 该应用程序需要能够通过蓝牙耳机接受 拒绝呼叫 但问题是添加到SCO后 audioManager startBluetoothSco audioManager isBluetoothScoOn
  • iOS 7 Core 蓝牙外设在后台运行

    我想要的是我的 iOS 设备始终宣传蓝牙 LE 服务 即使应用程序未运行 这样我就可以让另一台 iOS 设备扫描并找到它 我在这里遵循了苹果的后台说明 https developer apple com library ios docume
  • onBeaconServiceConnect 未调用

    和以前一样 我使用 Android Beacon 库 它已经工作了 我可以通过 BLE 低功耗蓝牙找到信标 但是现在 更新到最新版本的库后 现在方法onBeaconServiceConnect 不再跑了 请告诉我我需要做什么才能让它发挥作用
  • 如何获得蓝牙低功耗设备的实际名称?

    我需要从 ble 传感器获取友好的设备名称 例如 我想找到该设备并告诉用户他们已连接到 我的家庭传感器 我可以找到该设备 但我不知道如何找到该数据 在常规蓝牙中 我相信我可以使用BLUETOOTH DEVICE INFO或winsock 是

随机推荐

  • 4.OpenResty系列之Nginx负载均衡

    1 负载均衡配置 上篇文章中 代理仅仅指向一个服务器 但是 网站在实际运营过程中 大部分都是以集群的方式运行 这时需要使用负载均衡来分流 nginx 也可以实现简单的负载均衡功能 假设这样一个应用场景 将应用部署在 192 168 1 11
  • 非线性降维方法在高维数据可视化中的应用

    随着数据科学和机器学习的快速发展 我们面临着越来越多的高维数据 高维数据的可视化是理解和分析数据的重要手段之一 然而 传统的可视化方法在高维数据上往往无法有效展示数据的内在结构 为了解决这个问题 非线性降维方法应运而生 本文将探讨非线性降维
  • Android轮播图的画廊效果

    目录 效果图 介绍 使用 导入依赖 自定义属性 xml文件 活动代码 本文仿写百词斩 写在了碎片里 本文使用的是仿写魅族Banner的第三方库 链接在文章末尾 效果图 画廊效果 介绍 在Android中 轮播图的画廊效果通常是指一种类似于画
  • JUnit单元测试

    几乎全是基于JUnit4的 毕竟idea里面默认就是JUnit4 要是有基于JUnit5的会额外标出 框架介绍 1 是一个开源的java语言单元测试框架 2 特点 使用断言 Assertion 测试期望结果 方便组织运行测试 查看测试结果
  • 2023 年,网络安全领域有哪些令人印象深刻的大事件?

    一 美国医疗设备巨头遭到网络攻击 100万人敏感信息被泄露 医疗设备制造商ZOLL表示 1月份的一次网络攻击暴露了超过100万人的敏感信息 在提供给缅因州总检察长的文件中表明 事件始于1月28日 当时他们在其内部网络上 检测到异常活动 可能
  • Python Rich模块:打造绚丽多彩的命令行界面

    概要 在Python编程领域 命令行界面是开发者经常接触的环境之一 然而 传统的命令行界面通常只能呈现简单的文本信息 难以展现丰富的数据和交互效果 幸运的是 有一款名为Rich的Python模块 它能够让我们在命令行界面中创建出绚丽多彩的图
  • 无尘车间装修设计方案

    无尘车间是工业生产中非常重要的一个环节 它能够提供高度洁净的生产环境 保证产品在生产过程中的质量和安全性 因此 无尘车间的装修设计方案对于其使用效果和性能具有至关重要的影响 SICOLAB喜格 将详细介绍无尘车间的装修设计方案 包括设计原则
  • 苍穹分页查询

    controller 员工分页查询 employeeDTO return GetMapping page ApiOperation 员工分页查询 public Result
  • 基于知识图谱的推荐系统设计与优化

    随着互联网的快速发展 推荐系统在各个领域中扮演着重要的角色 然而 传统的推荐系统往往只基于用户行为数据进行推荐 忽略了用户的兴趣和需求之间的关联 为了解决这个问题 基于知识图谱的推荐系统应运而生 本文将探讨基于知识图谱的推荐系统的设计与优化
  • 扩展Spring MVC框架的消息转换器

    扩展Spring MVC框架的消息转换器 param Override protected void extendMessageConverters List
  • nodejs+vue+elementui咖啡商城销售系统qi99g

    现如今 咖啡在线销售是商业贸易中的一条非常重要的途径 可以把其从传统的实体模式中解放中来 网上销售可以为消费者提供巨大的便利 通过咖啡在线销售这个平台 可以使用户足不出户就可以了解现今的咖啡信息 为用户提供了极大的方便 咖啡在线销售的主要功
  • 怎么把视频字幕提取成文本?亲测好用的方法分享

    你是否曾经遇到过这样的问题 想要提取视频中的字幕 却不知道该如何操作 别担心 现在有一些视频字幕提取软件 它们可以帮助我们轻松地提取视频中的字幕 无论是英文还是中文 视频字幕提取软件都可以准确地提取出视频中的字幕文本 并保存为文本文件或复制
  • 视频转文字的app哪个好用?亲测好用的软件分享

    想象一下 当你在观看视频讲座或教学资料时 你希望把老师讲解的重点内容记录下来 以便后续的回顾和整理 但是手动输入文字真的是太麻烦了 这时 视频转文字软件就派上了用场 你只需简单地将视频上传到软件中 它会立即将视频中的对话或讲解转化为文字形式
  • C#8.0本质论第十五章--支持标准查询操作的集合接口

    C 8 0本质论第十五章 支持标准查询操作的集合接口 集合在C 3 0中通过称为语言集成查询 Language Integrated Query LINQ 的一套编程API进行了大刀阔斧的改革 通过一系列扩展方法和Lambda表达式 LIN
  • 大数相乘,限制:不可用 BigInt

    大数相乘 限制 不可用 BigInt 大数相乘 限制 不可用 BigInt 例如 输入 a 11111111111111111111 b 22222222222222222222 返回 246913580246913580241975308
  • 140-基于stm32单片机智能晾衣杆控制系统Proteus仿真+源程序

    资料编号 140 一 功能介绍 1 采用stm32单片机 LCD1602显示屏 独立按键 DHT11传感器 ds1302时钟 光敏传感器 蜂鸣器 LED灯 制作一个基于stm32单片机智能晾衣杆控制系统Proteus仿真 2 通过光敏传感器
  • 通过mount命令挂载另一台linux服务器的目录到本机

    说明 本次操作的目的是将另一台机器 192 168 1 100 的 backup目录挂载到本机的新建目录 back 1 在被挂载目录的机器上开启NFS服务并编辑 etc exports文件 1 1 查看是否已安装nfs 查看知道已安装 rp
  • 使用docker切换任意版本cuda使用GPU

    1 现存问题 在主机上运行很多下载来的机器学习代码时 这些大都运行在不同版本的tensorflow gpu或者pytorch等的包下的 但是 运行代码的过程中 存在匹配的问题 1 不同的版本的tensorflow gpu或pytorch对c
  • 138-基于stm32单片机汽车多功能仪表盘显示系统Proteus仿真+源程序

    资料编号 138 一 功能介绍 1 采用stm32单片机 LCD1602显示屏 独立按键 DHT11传感器 ds1302时钟 LED灯 蜂鸣器 电位器 制作一个基于stm32单片机汽车多功能仪表盘显示系统Proteus仿真 2 通过DHT1
  • 【经典蓝牙 SSP协议介绍】

    协议定义 SSP Secure Simple Pairing 安全简单配对 协议目的 1 为用户简化配对过程 2 维护或提高蓝牙无线技术的安全性 安全性指两点目标 1 被动窃听保护 2 中间人 MITM 攻击保护 协议流程 下面说下我认为的