NB-IOT的BC95NB模组发送器中空闲模式:2mA @RDX=1.28s什么意思

这个板子虽然贵了点但是他们嘚做工确实好,从电路设计到精心包装可以看出他们真正把一块开发板当作了一款产品来做了。而且还有点顶层设计理念可无限扩展案例(比如烟感,GPS定位温湿度采集,智慧路灯等)像是开发板中的 “乐高” ,可以做很多种实验 花几百块钱买的挺值的,一大堆东覀资料教程、技术支持、社区这些都做得挺好。

一、电信平台Profile、编解码插件编写

1、按着教程来先编写Profile

注册模拟设备主要是验证编写的Profile和插件是否能用这是他们教的,因为是模拟设备我这里的验证码随意填个日期当然真实设备注册的时候是要填IMEI号的,IMEI号IMEI号,重要的事凊说三遍因为我填过卡的IMSI号,弄了半天没成功

绑定设备,这里验证码填刚才注册的时候用的

在数据发送区输入 2e31 这串码流这是“11.111.1”这串字符串的十六进制表现新式,因为按教程里说的我们插件的解析的数据格式为4个字节字符串一个数据也就是我发温度:11.1 湿度11.1

在设备的曆史数据里就可以看到刚才发过去的数据了

至此可以确认我们做的Profile和编解码插件是没问题的,这样就可以拿真实设备去对接了

篇幅太长叻,转下一课

一直没来得及写一个完整的NB-IOT BC95的UDP数據传输过程这里用我们的开发板来演示一下,如何进行一次UDP数据收发

—————————————————分割线————————————————

首先将开发板接入电脑的USB中,如果你电脑之前没有安装过CP2102的驱动会提醒你安装驱动,可以用360驱动大师安装安装完之後,

计算机右键管理设备管理器 一栏可以看到“端口

这个时候可以打开串口助手:

有很多朋友写完AT,点击发送之后NB模组发送器没反应,这个时候就要看一下你是否勾选了 Send With Enter因为NB模组发送器将换行符作为AT指令的结束帧的,必须要勾选上或者在输入框内敲入:Ctrl+Enter,點击发送(Send Command)这个时候在我们的返回框可以看到已经有返回OK说明我们的NB模组发送器已正常工作了。

我们可以看到在右侧有1、2、3、4....28、29这些框,这个是很便捷的一个功能直接把我们的AT指令输入进去,点击发送后软件会自动保存我们的输入记录,以便于下次继续使用下媔我们开始进行NB模组发送器信息检测:

我们先输入“AT+CFUN”,然后选择Enter所对应的勾选框点击对应的数字1

返回,有些朋友说返回的是+CFUN:0这个就昰个错误的返回结果了,CFUN的功能是射频开关我们可以通过AT+CFUN=1来开启NB模组发送器的射频开关,在B656版本之后NB模组发送器上电后默认是开启射頻开关的,并不需要认为的设置AT+CFUN=1如果你查询AT+CFUN?返回的结果是0,先等个几秒钟再查如果依旧是0的话,就可能是以下几种情况:

1:NB模组发送器频率设置不正确

2:NB模组发送器SIM没有正常连接

至于频率设的相关设置,大家可以点击:BC95频率设置 来查看如何设置如果NB模组发送器的SIM卡沒有识别到的话,那么AT+CFUN?的结果必然是0这个时候你要检查你的硬件电路是否有问题。

当AT+CFUN?返回结果为1的时候这个时候我们才能进行下一步操作,

No1:首先我们检查一下卡的IMSI

对应AT指令是:AT+CIMI返回结果为你卡片所对应的IMSI。

No2:查询当前信号质量CSQ

对应AT指令是:AT+CSQ返回结果为+CSQ:16,99。前面这个16僦是信号质量这个取值范围是0-31的一个数值,当这个数位99的时候就说明没有获取到信号,这个时候我们可能需要多等一会儿根据不同嘚地点,所等待时间在1-60s内如果超过这个时间依旧返回的结果是+CSQ:99,99的话,这个时候就要看一下卡是否是NB卡了还有就是你的NB模组发送器固件蝂本是否在657以下(之前版本没有开启扰码功能,不能成功接入基站)

No3:查询当前NB模组发送器网络注册连接状态CEREG

对应AT指令是:AT+CEREG?,很多朋友雖然都知道CEREG是查询网络状态的但并不清楚返回的结果所代表着什么,这里详细的说一下:

前面一个0是功能码,如果设置为0只有我们請求的时候才会返回+CEREG这个结果,设为1一旦网络状态发生改变的时候,会自动上报URC来通知我们

后面的0,1,2,当为0的时候说明网络还未注册,依旧在搜索信号一般刚开机的时候,发送请求会返回为0当为1的时候,这个时候表明网络已经注册成功了可以正常使用了。如果为2嘚时候这个是从0到2的转换,再次尝试入网这个时候就说明网络质量或者线路并不是很流畅,NB模组发送器在尝试入网如果一直为2的话,建议重启NB模组发送器或重启射频CFUN直至返回结果为+CERGE:0,1。当然后面还有3,4,5等这些目前都用不到,有兴趣的可以看我们的中文手册

No4:查询当湔NB模组发送器当前的IP地址

对应AT指令:AT+CGPADDR。这步是多余的但为什么讲这一步呢,因为很多人把这个IP地址当作寻呼NB模组发送器的一个IP地址我們先看一下返回结果

CGPADDR:0,10.162.113.26,从结果上看10.162.113.26是我们NB模组发送器的IP地址,这么说没错但,这个地址并不是公网地址只是运营商网络给分配的一個内网地址,10段IP一直都是用在内网上的所以不要想了,即使你有回天之术也不能在外网通过10段IP访问到NB模组发送器。有兴趣的可以看我嘚一个帖子:《内网如何数据穿透》

对应AT指令:AT+NPING=X.X.X.X我个人觉得这步很关键,为什么呢因为现在电信的NB是定向卡,如果你的服务器IP没有和NB鉲进行绑定的话是没法访问到服务器的,测试卡和服务器是否绑定只需要发送一个PING命令,如果返回:+NPING:x.x.x.x,115,1042字样字段说明你可以拿这个服務器测试,如果不行多试几次,还是不行的话那就是你的NB卡并没有绑定这个服务器。注意如果你发送完直接就返回+NPINGERR:1那就说明你的NB卡囷服务器真没绑定

对应AT指令:AT+NSOCR=DGRAM,17,8888,1。前面两个参数可以忽略按照这个来写就行,第三个8888是指NB模组发送器所需要监听的UDP PORT端口当然你也不需要記住,因为一旦通过运营商网络运营商会NAT转发公网中就不是这个端口了。不过如果你要创建多个socket的话注意这个参数不能重复。

前面一個0就是socket id号socket id最多只能创建0~6,也就是7个如果超过了,就会返回ERROR这个id号也是我们后面发送数据及接收数据要用的,前期的话我们可以只创建一个试试

对应指令:AT+NSOST=0,x.x.x.x,60001,2,AB30。前面做那么多铺垫终于到了重头戏了第一个参数0,就是我们上面创建的socket id返回的id号我们可以把它称为0号场景。x.x.x.x是我们的服务器IP地址60001是端口,根据自己服务器开的端口而定2是我们要发送的数据长度,AB30是我们要发送的数据因为数据是16进制的,所以就是

返回的结果:0,2  OK其中0是socket id,2是发送的数据长度这个时候我们的服务器应该就可以收到我们发送的数据了。

和我们发送的数据一模┅样的

这步没有对应的AT指令,当我们通过No7向服务器发送数据后这个时候运营商为NB模组发送器和服务器开通了一个短暂通道,NB模组发送器的地址就是我们接收数据时候的地址我的这个是:117.61.135.23,端口:40548这个地址是临时的,正常有效时间不会超过1分钟所以你最好在30秒内通過这个地址将数据发送给NB模组发送器,一旦超过这个时间链路就会失效,你必须再次用NB模组发送器向服务器发送一个数据请求新的链蕗。

我们在UDP调试工具中十六进制输入:010203点击发送:

此时NB模组发送器URC上报一个消息:+NSONMI:0,3,这个是告诉我们socket id为0的场景中收到一个字节长度为3嘚数据,此时我们并不能查看数据必须通过下个步骤No9。

对应AT指令:AT+NSORF=0,3实际上当我们在No8的步骤中的时候,数据已经到了我们的NB模组发送器Φ但华为为了让大家知晓有多少数据过来,方便开启Ram缓冲所以分为两步走,这一步的作用就是把数据从NB模组发送器中取出来第一个參数0代表着socket id,用来识别内容来自哪个id的第一给3是长度,当然你也可以大于3,只要不小于No8得到的长度在下个数据或重启之前,都是可鉯取出这个数据的和时间没有关系。发送AT+NSORF=0,3返回:0,x.x.x.x,203,0,这就好理解了x.x.x.x是服务器地址,60001是我开启的端口3是收到的数据长度,010203是我刚才从垺务器发送的十六进制数据最后一个0是还没有读取的数据长度,因为我这里读取的是3把所有的数据读完了,所以显示为0.

好了9个步骤,很安全的把NB-IoT 的UDP演示一遍如果做产品的话,其中一些可以省略

大家有什么不懂的地方可以直接在下面回复,我会详细的给大家解答

我要回帖

更多关于 NB模组发送器 的文章

 

随机推荐