Pentesting BLE - Bluetooth Low Energy
Reading time: 5 minutes
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。
介绍
自 Bluetooth 4.0 规范发布以来,BLE 仅使用 40 个频道,覆盖 2400 到 2483.5 MHz 的范围。相比之下,传统蓝牙在相同范围内使用 79 个频道。
BLE 设备通过发送 advertising packets (beacons) 进行通信,这些数据包向其他附近设备广播 BLE 设备的存在。这些信标有时也会 发送数据。
监听设备,也称为中央设备,可以通过向广告设备发送特定的 SCAN request 来响应广告数据包。对该扫描的 response 使用与 advertising 数据包相同的结构,并包含无法在初始广告请求中容纳的附加信息,例如完整的设备名称。
前导字节同步频率,而四字节访问地址是 connection identifier,用于多个设备尝试在同一频道上建立连接的场景。接下来,协议数据单元 (PDU) 包含 advertising data。PDU 有几种类型;最常用的是 ADV_NONCONN_IND 和 ADV_IND。如果设备 不接受连接,则使用 ADV_NONCONN_IND PDU 类型,仅在广告数据包中传输数据。如果设备 允许连接,并且在 连接 建立后 停止发送广告 数据包,则使用 ADV_IND。
GATT
Generic Attribute Profile (GATT) 定义了 设备应如何格式化和传输数据。当您分析 BLE 设备的攻击面时,您通常会将注意力集中在 GATT(或 GATTs)上,因为它是 设备功能触发 和数据存储、分组及修改的方式。GATT 以 16 位或 32 位值的表格形式列出设备的特性、描述符和服务。特性是 在中央设备和外设之间发送的 数据 值。这些特性可以具有 描述符,以 提供有关它们的附加信息。如果 特性 与执行特定操作相关,通常会在 服务 中 分组。
Enumeration
hciconfig #Check config, check if UP or DOWN
# If DOWN try:
sudo modprobe -c bluetooth
sudo hciconfig hci0 down && sudo hciconfig hci0 up
# Spoof MAC
spooftooph -i hci0 -a 11:22:33:44:55:66
GATTool
GATTool 允许 建立 与另一个设备的 连接,列出该设备的 特征,并读取和写入其属性。
GATTTool 可以使用 -I
选项启动交互式 shell:
gatttool -i hci0 -I
[ ][LE]> connect 24:62:AB:B1:A8:3E Attempting to connect to A4:CF:12:6C:B3:76 Connection successful
[A4:CF:12:6C:B3:76][LE]> characteristics
handle: 0x0002, char properties: 0x20, char value handle:
0x0003, uuid: 00002a05-0000-1000-8000-00805f9b34fb
handle: 0x0015, char properties: 0x02, char value handle:
0x0016, uuid: 00002a00-0000-1000-8000-00805f9b34fb
[...]
# Write data
gatttool -i <Bluetooth adapter interface> -b <MAC address of device> --char-write-req <characteristic handle> -n <value>
gatttool -b a4:cf:12:6c:b3:76 --char-write-req -a 0x002e -n $(echo -n "04dc54d9053b4307680a"|xxd -ps)
# Read data
gatttool -i <Bluetooth adapter interface> -b <MAC address of device> --char-read -a 0x16
# Read connecting with an authenticated encrypted connection
gatttool --sec-level=high -b a4:cf:12:6c:b3:76 --char-read -a 0x002c
Bettercap
# Start listening for beacons
sudo bettercap --eval "ble.recon on"
# Wait some time
>> ble.show # Show discovered devices
>> ble.enum <mac addr> # This will show the service, characteristics and properties supported
# Write data in a characteristic
>> ble.write <MAC ADDR> <UUID> <HEX DATA>
>> ble.write <mac address of device> ff06 68656c6c6f # Write "hello" in ff06
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。