博客
关于我
501-STM32+Air724UG基本控制篇(自建物联网平台)-移植使用-移植单片机MQTT底层包到自己的工程项目
阅读量:147 次
发布时间:2019-02-28

本文共 893 字,大约阅读时间需要 2 分钟。

说明如何将工程中的MQTT包移植到用户自主工程

本节将详细说明如何将工程中的MQTT包移植到用户自主工程中。请确保在移植前已实现稳定的TCP连接服务器功能。

文件夹结构

移植所需文件夹包括以下两个部分:

  • 模板程序文件夹:提供了一个基础模板,用于展示移植过程。
  • MQTT文件夹:包含处理MQTT协议的核心文件。
    • mqtt_msg文件:实现了最底层的MQTT协议处理。
    • mqtt.c文件:在mqtt_msg基础上封装了一层,增加了数据缓存管理(采用环形队列)。
    • mem文件夹:提供了缓存管理程序。
  • 以STM32工程为例说明移植步骤

  • 将文件添加至工程

    • 设置.h文件路径,确保文件能正确包含。
  • 编译工程

    • 打开错误报告,逐步修正编译问题。
  • 替换TCP发送函数

    • 根据实际需求修改发送逻辑。
  • 初始化定时器

    • 将mqtt_time_data(&mymqtt);放入1ms定时器中断中。
  • 注册MQTT功能

    • 初始化并注册MQTT相关函数,如订阅、发布等。
  • 完成TCP连接

    • 通过TCP协议连接MQTT服务器。
    • 处理服务器返回的数据,调用mqtt_connect_ack函数。
    • 根据返回状态判断连接成功或失败,并调用相应回调函数。
  • 实现消息处理

    • 增加轮询处理函数,处理订阅消息。
    • 发布消息时,打包数据并发送。
  • 处理服务器返回数据

    • 解析并处理MQTT消息。
  • 注意事项

  • mqtt.h中的mqtt_send_buff_len默认值为500

    • 用户需根据实际需求调整发送缓冲区大小。
    • 为避免内存溢出,默认超出长度的数据会被丢弃。
  • 消息发布成功判断

    • 只有当消息等级1或2时才会触发成功函数。
    • 确保服务器接收数据后才能进入处理。
  • 网络模块通信注意事项

    • 如果网络模块不支持透传模式:
      • 使用串口2与模块通信时,需注意数据包格式。
      • 发送时需发送AT+CIPSEND命令,获取返回状态。
      • 接收时需解析数据包,提取有效数据。
  • 接收数据处理建议

    • 建议采用环形缓存或双缓冲技术优化接收处理。
  • 版本说明

    如发现与当前文件不兼容的情况,请直接替换相关文件。未来将持续更新和完善文件,尽量保持版本兼容。如有不兼容问题,会在文件说明中进行详细说明。

    转载地址:http://fcdc.baihongyu.com/

    你可能感兴趣的文章
    Oracle spatial 周边查询SQL
    查看>>
    Oracle Spatial空间数据库建立
    查看>>
    UML— 活动图
    查看>>
    oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
    查看>>
    oracle SQLserver 函数
    查看>>
    oracle sql分组(group,根据多个内容分组)在select之后from之前 再进行select查询,复杂子查询的使用
    查看>>
    Oracle Statspack分析报告详解(一)
    查看>>
    oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
    查看>>
    Oracle Validated Configurations 安装使用 说明
    查看>>
    oracle where 条件的执行顺序分析1
    查看>>
    oracle 中的 CONCAT,substring ,MINUS 用法
    查看>>
    Oracle 中的 decode
    查看>>
    oracle 中表一对多取多方的最新的一条数据
    查看>>
    oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
    查看>>
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 修改数据库表数据提交之后进行回滚
    查看>>
    UML-总结
    查看>>
    oracle 内存参数示意图
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>