藍牙BLE MTU規則與約定
1. 問(wèn)題引言:
想在gatt client上(一般是手機上)傳輸長(cháng)一點(diǎn)的數據給gatt server(一般是一個(gè)Bluetooth smart設備,即只有BLE功能的設備),但通過(guò)
[java]
writeCharacteristic(BluetoothGattCharacteristic)
來(lái)寫(xiě)的時(shí)候發(fā)現最多只能寫(xiě)入20個(gè)byte的數據。
這篇文章會(huì )回答下面幾個(gè)問(wèn)題:
1)為什么會(huì )是20?
2)如何突破20?
3)如何更優(yōu)雅的來(lái)實(shí)現?
2. 為什么為限制成20個(gè)字節?
core spec里面定義了ATT的默認MTU為23個(gè)bytes, 除去ATT的opcode一個(gè)字節以及ATT的handle 2個(gè)字節之后,剩下的20個(gè)字節便是留給GATT的了。
考慮到有些Bluetooth smart設備功能弱小,不敢太奢侈的使用內存空間,因此core spec規定每一個(gè)設備都必須支持MTU為23。
在兩個(gè)設備連接初期,大家都像新交的朋友一樣,不知對方底細,因此嚴格的按照套路來(lái)走,即最多一次發(fā)20個(gè)字節,是最保險的。
由于ATT的最大長(cháng)度為512byte,
因此一般認為MTU的最大長(cháng)度為512個(gè)byte就夠了,再大也沒(méi)什么意義,你不可能發(fā)一個(gè)超過(guò)512的ATT的數據。
所以ATT的MTU的最大長(cháng)度可視為512個(gè)bytes。
3. 如何突破20?
很簡(jiǎn)單嘛,改變傳輸的ATT的MTU就行了,大家經(jīng)過(guò)友好的協(xié)商,得到雙方都想要的結果,是最好的。在Android上(API 21),改變ATT MTU的接口為:
public boolean requestMtu (int mtu)
Added in API level 21
Request an MTU size used for a given connection.
When performing a write request operation (write without response), the data sent is truncated to the MTU size. This function may be used to request a larger MTU size to be able to send more data at once.
A onMtuChanged(BluetoothGatt, int, int) callback will indicate whether this operation was successful.
Requires BLUETOOTH permission.
Returns
true, if the new MTU value has been requested successfully
大聲的說(shuō)出來(lái)你想要一下子傳多少,調用上面的接口就可以了,然后在下面的函數中看最終結果(當然了,如果你的peripheral申請改變MTU并且成功的話(huà),那這個(gè)回調也會(huì )被調用):
@Override
public void onMtuChanged(BluetoothGatt gatt, int mtu, int status) {
super.onMtuChanged(gatt, mtu, status);
if (status == BluetoothGatt.GATT_SUCCESS) {
this.supportedMTU = mtu;//local var to record MTU size
}
}
之后你就可以快樂(lè )的發(fā)送supported MTU-3的長(cháng)度的數據了。
4. 如何優(yōu)雅的來(lái)實(shí)現?
萬(wàn)一對方設備不同意你的請求怎么辦?
對于app來(lái)說(shuō),一般是知道自己要最****送多少數據的,例如一次要發(fā)100個(gè)bytes,那么就首先試試申請一下103,失敗的話(huà),則申請一下53,即二分法,剩下的只能自己分段拆著(zhù)發(fā)了。
一般來(lái)講,app的開(kāi)發(fā)者和對端設備的開(kāi)發(fā)者都是同一伙兒人,這是好事,他們可以根據自己設備的硬件情況,來(lái)商量MTU應該是多少。
藍牙BLE MTU規則與約定-zhenhuaqin-ChinaUnix博客
*博客內容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀(guān)點(diǎn),如有侵權請聯(lián)系工作人員刪除。