STM32通过NB-IoT模块实现远程告警推送

liftword19小时前技术文章4

一、项目概述

本系统以STM32F103C8T6作为主控核心,通过串口控制NB-IoT通信模块(移远BC26),实现对外设状态的远程监测和异常自动告警推送(如温度超限、设备震动异常等)。支持通过UDP或CoAP方式向物联网平台发送告警数据,适合用作边缘节点、监控终端等低功耗远程告警场景


二、硬件与模块连接概述

模块

接口

功能

STM32F103C8

UART1

与NB-IoT模块通信

NB-IoT BC26

UART

与运营商物联网平台通信

DS18B20

1-Wire

温度传感器,用于告警检测

GPIO外设

GPIO

可扩展震动、烟雾传感器等

电源注意事项: BC26上电瞬间电流需求较大,建议外接大电容或LDO供电稳压。


三、NB-IoT通信模块管理

3.1 通信初始化流程

void NB_SendCmd(const char* cmd)
{
    HAL_UART_Transmit(&huart1, (uint8_t*)cmd, strlen(cmd), 1000);
    HAL_Delay(500); // 可使用串口接收响应并分析返回状态
}

void NB_Init(void)
{
    NB_SendCmd("AT\r\n");
    NB_SendCmd("ATE0\r\n");                       // 关闭回显
    NB_SendCmd("AT+CMEE=2\r\n");                  // 打开详细错误报告
    NB_SendCmd("AT+CGDCONT=1,\"IP\",\"iot.mnc\" \r\n");  // 设置接入点
    NB_SendCmd("AT+CGATT=1\r\n");                 // 附着网络
    NB_SendCmd("AT+CSQ\r\n");                     // 查询信号质量
}

四、AT命令封装与数据推送接口

4.1 UDP方式发送告警数据

void NB_UDP_Open(void)
{
    NB_SendCmd("AT+NSOCR=\"DGRAM\",17,3005,1\r\n"); // UDP socket监听3005端口
}

void NB_UDP_Send(const char* ip, int port, const char* msg)
{
    char cmd[128];
    sprintf(cmd, "AT+NSOST=0,\"%s\",%d,%d,\"", ip, port, strlen(msg) * 2);

    HAL_UART_Transmit(&huart1, (uint8_t*)cmd, strlen(cmd), 1000);
    for (int i = 0; i < strlen(msg); i++)
        printf("%02X", msg[i]);  // 发送HEX格式数据

    printf("\"\r\n");
}

注意:BC26中UDP数据采用HEX字符串发送,每字节需转换为2位十六进制字符。


五、告警检测逻辑实现

以温度超限为例,读取DS18B20温度值,当超过阈值时触发上报。

5.1 读取DS18B20温度(简化版)

float Read_Temperature(void)
{
    // DS18B20初始化、发送指令、读取ScratchPad等略
    return 29.6f; // 模拟测试用
}

5.2 告警处理函数

#define TEMP_THRESHOLD 30.0f

void Alarm_CheckAndReport(void)
{
    float temp = Read_Temperature();
    if (temp > TEMP_THRESHOLD)
    {
        char msg[64];
        sprintf(msg, "ALERT:TEMP=%.1f", temp);
        NB_UDP_Send("120.XX.XX.XX", 5683, msg);  // 平台IP和端口
    }
}

六、主循环与状态管理机制

int main(void)
{
    HAL_Init();
    SystemClock_Config();
    MX_USART1_UART_Init();
    DS18B20_Init();
    NB_Init();
    NB_UDP_Open();

    while (1)
    {
        Alarm_CheckAndReport();
        HAL_Delay(10000);  // 每10秒检查一次
    }
}

可根据场景使用 RTC+低功耗模式 实现周期唤醒,降低NB模块功耗。


七、异常处理与状态反馈

7.1 信号检测失败处理

void Check_Signal(void)
{
    char resp[64] = {0};
    NB_SendCmd("AT+CSQ\r\n");
    // 解析resp内容,若信号质量低于8,提示“无网络”
}

7.2 模块掉线恢复重连

void NB_Reconnect(void)
{
    NB_SendCmd("AT+NRB\r\n");  // 复位模块
    HAL_Delay(5000);
    NB_Init();
    NB_UDP_Open();
}

可在主循环中加入“失败次数计数器”,在连续上报失败或无响应时调用重连。


八、平台接收端说明(可选)

示例:阿里云物联网平台或OneNet平台

如果使用公网平台,需将BC26注册到平台并配置数据上报路径。也可以在本地搭建UDP接收服务器:

# Python UDP server (for测试)
import socket
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sock.bind(('0.0.0.0', 5683))
while True:
    data, addr = sock.recvfrom(1024)
    print("告警内容:", data)

九、调试建议

  • 使用串口调试助手查看NB模块返回AT结果,判断连接情况。
  • NB模块必须有有效的NB SIM卡,并在支持NB网络的环境中使用。
  • 数据上报格式可自定义,建议使用JSON压缩或HEX格式避免中文乱码。
  • 模块休眠与上报周期之间建议用状态机管理,防止阻塞主循环。

十、结语与拓展方向

本文展示了一个完整的STM32 + NB-IoT告警终端的实现过程,从模块初始化到异常检测、数据推送,每一步均提供了可运行的程序实例。系统可根据场景扩展如下功能:

  • 多种传感器融合(烟雾/水浸/门磁)
  • MQTT协议支持(若模块支持)
  • 数据本地缓存与掉线补传
  • 加入AES加密保护告警数据

相关文章

Python实现串口助手 - 03串口功能实现

 串口调试助手是最核心的当然是串口数据收发与显示的功能,pzh-py-com借助的是pySerial库实现串口收发功能,今天痞子衡为大家介绍pySerial是如何在pzh-py-com发挥功能的。一、...

齐安安小课堂 | 串口数据抓取以及串口数据模拟

各位同学们好,好久不见!齐安安小课堂又双叒叕开课啦~本期来讲讲在工控现场使用的设备中有哪些普遍存在又容易被忽视的安全隐患只有重视每一个小细节才能对工业安全做出更好的防护哦~引言在工控现场中,存在着几乎...

200行Python代码实现串口调试助手之联合调试

软件开发离不开调试,调试手段分两种:一是黑盒调试,即直接从输入 / 输出角度测试软件功能是否正常,这种方式仅能发现问题,但无法直接定位问题原因所在;二是白盒调试,即直接拿源代码在线 debug,pyt...

200行Python代码实现串口调试助手之环境搭建

在写 pzh-py-com 时需要先搭好开发和调试环境,下表列出了开发过程中会用到的所有软件/ 工具包:一、涉及工具列表二、开发环境搭建(Python + pySerial + wxPython +...

同事开玩笑说:你这个python程序要是外流出去了,可能会有危险

引言公司因为业务原因,购入了一些高灵敏高精度的振动传感器。老板说:“拿去进行测试,看看数据如何?”吭哧吭哧接入数据,一看,确实精度和灵敏度非常高。具体多高呢?将传感器固定在相关的结构物上,在办公室中人...

Python实现串口助手 - 02界面构建

今天给大家介绍的是串口调试工具pzh-py-com诞生之界面构建。  一个软件的UI界面是非常重要的,这是软件与用户交互的接口,软件功能即使再强大,但如果没有清晰的UI界面,那也发挥不出软件的功能,使...