0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

LoRaWAN協(xié)議之OTAA入網(wǎng)流程

454398 ? 來源:博客園 ? 作者:博客園 ? 2020-12-04 14:52 ? 次閱讀

通過OTAA方式入網(wǎng)的設(shè)備,通訊時(shí)使用的KEY需要通過服務(wù)器獲得,在入網(wǎng)之間,設(shè)備無法通訊。

相關(guān)的OTAA入網(wǎng)流程已經(jīng)在上一章中講解過了,有興趣的可以去看看**LoRaWAN協(xié)議(五)__OTAA入網(wǎng)方式詳述**

這一章講解的是OTAA中的密鑰生成過程。

其中使用到的庫函數(shù)都是從semtech的官方庫中來的,官方庫代碼鏈接:LoRaMac-node。

詳解

設(shè)備在通訊時(shí),會(huì)使用的密鑰有NwkSKey 和AppSKey。

生成的公式如下:

NwkSKey = aes128_encrypt(AppKey, 0x01 | AppNonce | NetID | DevNonce | pad16)

AppSKey = aes128_encrypt(AppKey, 0x02 | AppNonce | NetID | DevNonce | pad16)

可以看到相關(guān)的參數(shù)一共有四個(gè):
1.AppNonce
2.NetID
3.DevNonce
4.pad16

其中AppNonce、NetID、pad16 是產(chǎn)生于服務(wù)器的,DevNonce產(chǎn)生于node設(shè)備本身。

還是使用LoRaWAN協(xié)議(五)這篇文章中使用的包數(shù)據(jù)來進(jìn)行分析。

這里,我們調(diào)用官方庫的接口,因?yàn)槲覀冞@里只是熟悉協(xié)議,并不是要研究Key的生成算法

如果不明白數(shù)據(jù)協(xié)議的,可以去看LoRaWAN協(xié)議(五)這篇文章

提取DevNonce

1.GW->NS JSON包,從中提取出來DevNonce,

data為MAC層數(shù)據(jù),為join_request message,其數(shù)據(jù)包格式為

base64解碼:

x00 x01 x00 x00 x20 x00 xc5 x26

x2c x16 x10 x16 x20 x00 x77 x4a

x00 x54 x7b x40 x2d xe1 x9a

得到的數(shù)據(jù):

可以得到DevNonce的值為0x7b54

提取AppNonce、NetID、CFList

2.NS->GW JSON包,其中txpk.data為包含了MAC層數(shù)據(jù)內(nèi)容

data base64 decode:

x20 xfa x80 x29 x74 x3b x2d x2f

xc2 x99 x85 x42 x0f x2f x0a xde

x4e

根據(jù)LoRaWAN specification 可知,join_accept message的格式如下:

但是這個(gè)數(shù)據(jù)是加密的,需要使用AppKey進(jìn)行解密

所以,我們需要先使用AppKey解密join_accept message

payload為join_accept message,此處為

x20 xfa x80 x29 x74 x3b x2d x2f

xc2 x99 x85 x42 x0f x2f x0a xde

x4e

解密之后的數(shù)據(jù)存放在LoRaMacRxPayload數(shù)組中。

uint8_t LoRaMacAppKey[] = {0x2B, 0x7E, 0x15, 0x16, 0x28, 0xAE, 0xD2, 0xA6, 0xAB, 0xF7, 0x15, 0x88, 0x09, 0xCF, 0x4F, 0x3C};

LoRaMacJoinDecrypt( payload + 1, size - 1, LoRaMacAppKey, LoRaMacRxPayload + 1 );

LoRaMacRxPayload[0] = payload[0];

可以得到解析之后的數(shù)組

0x20 0x43 0x75 0xcb 0x24 0x0 0x0 0x2

0x0 0x0 0x48 0x3 0x0 0x82 0xc9 0xd0

0xf9

根據(jù)協(xié)議,我們可以得到:

AppNonce:x43 x75 xcb

NetID:x24 x0 x0

DevNonce:0x7b54

pad16:沒有

至此,我們就具備生成密鑰的所有參數(shù)了

產(chǎn)生AppSKey 和 NwkSKey

最后,我們再調(diào)用

LoRaMacJoinComputeSKeys( LoRaMacAppKey, LoRaMacRxPayload + 1, LoRaMacDevNonce, LoRaMacNwkSKey, LoRaMacAppSKey );

就可以生成AppSKey和NwkSKey了。

得到的NwkSKey為

0xde 0x3 0x33 0x1a 0xeb 0x42 0x54 0xe9

0x72 0x7b 0x6f 0xaf 0xbf 0x13 0xdb 0x3d

得到的AppSKey為

0xe0 0x46 0x9e 0x44 0x9c 0x57 0x47 0x8c

0xbe 0xa7 0x25 0xda 0x84 0xf0 0x13 0x97

對比之間抓包的AS->NS的入網(wǎng)信息

AS->NS 發(fā)送入網(wǎng)信息,可以知道,生成的密碼是正確的了。

當(dāng)然最好是進(jìn)行實(shí)際負(fù)載的驗(yàn)證,我也寫了兩個(gè)小程序進(jìn)行了驗(yàn)證,證明了這兩個(gè)Key確實(shí)是正確的。

兩個(gè)小程序的鏈接:

decode_aes_base64

generate_key

至此,我所知的OTAA入網(wǎng)方面的協(xié)議就完了。
編輯:hfy

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    12

    文章

    8873

    瀏覽量

    84972
  • lorawan
    +關(guān)注

    關(guān)注

    3

    文章

    309

    瀏覽量

    23777
收藏 人收藏

    評論

    相關(guān)推薦

    基于lorawan協(xié)議的幾種常見入網(wǎng)方法

    OTAA(Over-The-Air Activation),是LoRaWAN的一種空中入網(wǎng)方式。當(dāng)node在上電的時(shí)候處于非入網(wǎng)狀態(tài)時(shí),需要先入網(wǎng)
    的頭像 發(fā)表于 11-11 07:18 ?1.6w次閱讀
    基于<b class='flag-5'>lorawan</b><b class='flag-5'>協(xié)議</b>的幾種常見<b class='flag-5'>入網(wǎng)</b>方法

    st官網(wǎng)lora節(jié)點(diǎn)程序OTAA模式加入網(wǎng)絡(luò)后,把網(wǎng)關(guān)與服務(wù)器的連接斷開后,節(jié)點(diǎn)是否一直持續(xù)發(fā)送數(shù)據(jù)?

    st官網(wǎng)lora節(jié)點(diǎn)程序OTAA模式加入網(wǎng)絡(luò)后,把網(wǎng)關(guān)與服務(wù)器的連接斷開后,節(jié)點(diǎn)是否一直持續(xù)發(fā)送數(shù)據(jù)?
    發(fā)表于 04-28 06:54

    國產(chǎn)無線脈沖水表LoRaWAN方案分享

    功能,不受磁干擾。06LoRaWAN:持OTAA/ABP入網(wǎng)模式;支持CN470/EU868/AU915頻段;支持指令設(shè)置ADR功能/發(fā)送確認(rèn)或非確認(rèn)報(bào)文/APP端口號/DevEui/AppEui/AppKey/DevAddr/
    發(fā)表于 04-03 15:45

    詳解LoRaWAN網(wǎng)絡(luò)架構(gòu)和協(xié)議內(nèi)容

    本文是一篇LoRaWAN的科普介紹,你已經(jīng)在朋友圈看過無數(shù)蜻蜓點(diǎn)水的LoRaWAN文章,是時(shí)候來一篇真正的技術(shù)干貨了。本文先從橫向介紹下LoRaWAN的背后勢力和網(wǎng)絡(luò)部署情況,然后縱向講解了網(wǎng)絡(luò)架構(gòu)和具體的
    的頭像 發(fā)表于 06-16 07:18 ?2.6w次閱讀
    詳解<b class='flag-5'>LoRaWAN</b>網(wǎng)絡(luò)架構(gòu)和<b class='flag-5'>協(xié)議</b>內(nèi)容

    介紹STM32和LoRaWAN協(xié)議及其應(yīng)用

    入門指南_STM32和LoRaWAN協(xié)議
    的頭像 發(fā)表于 07-02 08:29 ?1.1w次閱讀

    LoRa節(jié)點(diǎn)如何以OTAA方式入網(wǎng)TTN服務(wù)器?

    前言 當(dāng)你將LoRaWAN網(wǎng)關(guān)和LoRa節(jié)點(diǎn)都添加到TTN上,這時(shí)候,你需要通過ABP或OTAA方式,配置LoRa節(jié)點(diǎn)的參數(shù),才能最終實(shí)現(xiàn)入網(wǎng)到TTN的目的。 如何將LoRaWAN網(wǎng)關(guān)
    發(fā)表于 05-15 15:01 ?1550次閱讀

    LoRa節(jié)點(diǎn)如何以ABP方式入網(wǎng)TTN服務(wù)器?

    TTN,可參考文章LoRa節(jié)點(diǎn)如何以OTAA方式入網(wǎng)TTN。 如何將LoRaWAN網(wǎng)關(guān)添加到TTN上,可參考文章如何將樹莓派網(wǎng)關(guān)連接到TTN手把手教你如何將樹莓派網(wǎng)關(guān)連接到服務(wù)器第四
    發(fā)表于 05-19 09:33 ?2032次閱讀

    OTAA和ABP入網(wǎng)方式的區(qū)別

    已獲小七老師授權(quán),小七老師是騰訊云在線課程講師,點(diǎn)擊鏈接可以觀看課程視頻。 LoRaWAN終端兩種不同的入網(wǎng)方式,在LoRaWAN協(xié)議中,它們分別稱為
    發(fā)表于 03-13 09:36 ?3158次閱讀

    弱網(wǎng)區(qū)域下LoRa節(jié)點(diǎn)入網(wǎng)方式該如何選擇

    小七老師授權(quán),小七老師是騰訊云在線課程講師,點(diǎn)擊鏈接可以觀看課程視頻。 LoRa終端兩種不同的入網(wǎng)方式,在LoRa協(xié)議中,它們分別稱為OTAA和ABP。在上一篇文章“LoRaWAN終端
    發(fā)表于 03-13 09:34 ?845次閱讀

    LoRaWAN網(wǎng)絡(luò)協(xié)議的優(yōu)勢介紹

    物聯(lián)網(wǎng)很多應(yīng)用現(xiàn)在都普遍用了LoRa技術(shù)的芯片,然而沒有使用LoRaWan網(wǎng)絡(luò)協(xié)議。經(jīng)過調(diào)查發(fā)現(xiàn),沒有使用LoRaWAN網(wǎng)絡(luò)協(xié)議的原因有:應(yīng)用點(diǎn)數(shù)少、規(guī)模小,有的是因?yàn)?/div>
    發(fā)表于 03-11 12:10 ?1132次閱讀

    OTAA節(jié)點(diǎn)是如何入網(wǎng)

    在之前的文章中向大家介紹了LoRaWAN協(xié)議中節(jié)點(diǎn)的兩種不同的入網(wǎng)方式OTAA和ABP的區(qū)別,本文主要介紹了OTAA節(jié)點(diǎn)是如何
    發(fā)表于 03-19 13:50 ?1181次閱讀

    淺談LoRa終端ABP入網(wǎng)方式

    在介紹ABP入網(wǎng)方式之前,我們先來回憶下OTAA入網(wǎng)方式。OTAA入網(wǎng)方式的節(jié)點(diǎn)需要發(fā)送一條Join Request
    發(fā)表于 04-02 17:30 ?1567次閱讀

    基于安信可Ra-08系列LoRaWAN模組的入網(wǎng)流程

    最近LoRaWAN技術(shù)很火熱,在我們的一些開發(fā)者交流群中,也經(jīng)常有開發(fā)者討論LoRaWAN的一些技術(shù)應(yīng)用。今天就分享一篇教程——基于安信可Ra-08系列LoRaWAN模組的入網(wǎng)
    的頭像 發(fā)表于 05-19 19:23 ?2232次閱讀
    基于安信可Ra-08系列<b class='flag-5'>LoRaWAN</b>模組的<b class='flag-5'>入網(wǎng)</b><b class='flag-5'>流程</b>

    基于安信可Ra-08系列LoRaWAN模組的入網(wǎng)流程

    最近LoRaWAN技術(shù)很火熱,在我們的一些開發(fā)者交流群中,也經(jīng)常有開發(fā)者討論LoRaWAN的一些技術(shù)應(yīng)用。 今天就分享一篇教程——基于安信可Ra-08系列LoRaWAN模組的入網(wǎng)
    的頭像 發(fā)表于 05-21 09:19 ?1272次閱讀
    基于安信可Ra-08系列<b class='flag-5'>LoRaWAN</b>模組的<b class='flag-5'>入網(wǎng)</b><b class='flag-5'>流程</b>

    應(yīng)用筆記 | STM32WL LoRa節(jié)點(diǎn)入網(wǎng)失敗問題分析總結(jié)

    關(guān)鍵字:STM32WL,LoRaWAN,入網(wǎng),OTAA ? 目錄預(yù)覽 1.引言 2.LoRaWAN網(wǎng)絡(luò)架構(gòu) 3.創(chuàng)建CubeMX工程 4.移植過程中可能遇到的問題 5.小結(jié) 0 1 前
    的頭像 發(fā)表于 09-27 17:10 ?2061次閱讀