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

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

说明

这节详细说明一下如何把工程里面的MQTT包移植到用户自己的工程.

注意:首先确定自己已经实现了使用TCP连接服务器!

该底层包适用于所有的单片机,和所有的网络模块.

该教程以STM32工程为例子说明移植过程.

文件夹说明

1.移植使用的是下面两个文件夹里面的文件

我准备了一个空模板程序,然后在这个模板上演示移植过程.

 

 

 

2.MQTT文件夹

 

 

 

mqtt_msg 文件作为最底层的最直接的MQTT协议处理文件.

mqtt.c 文件 是我在mqtt_msg的基础上又封装了一层

这一层增加了数据缓存管理,缓存管理采用环形队列实现,所有的数据都储存在缓存里面

另一方面还有处理消息等级1,2的消息,心跳包自动发送等.

有了这一层的封装,用户只需简单的配置即可实现稳定可靠的MQTT通信.

 

3.mem文件夹

 

 

 

mem文件夹里面是我写的缓存管理程序

 

开始移植 

1.把文件添加到工程,设置下.h路径

 

2.编译一下工程,打开这个错误

 

 

 

3.替换自己的TCP发送函数

 

 

 

4.把 mqtt_time_data(&mymqtt); 放到1ms定时器中断中.

 

 

 

 

 

 

 

5.初始化和注册MQTT几个函数,订阅,发布等函数

 

 

6.连接TCP服务器,发送连接MQTT协议

 

 

 

把上面的协议发给MQTT服务器以后,MQTT服务器会返回数据

需要把返回的数据交给 int  mqtt_connect_ack(unsigned char *buff) 函数处理

如果该函数返回 0 说明连接上了MQTT服务器,然后调用 mymqtt.connectCb();执行连接回调函数

 

 

 

 

 

 

7.加上需要不停轮训的函数和处理MQTT消息的函数

 

 

 

 

8.按照上面的步骤已经移植完成(述说下执行流程)

1.首先控制模块以TCP方式连接服务器,连接上以后发送MQTT连接协议

 

 

 

2.判断服务器返回的数据,如果连接上MQTT服务器,调用连接成功回调函数

并在连接成功回调函数中订阅主题.

 

 

 

 

 

 

 

3.订阅主题的协议都打包进了缓存,从缓存提取并发送出去.

注:后面发布消息,发送心跳包数据也是全部打包进了缓存!

 

 

 

 

 

 

 

 

4.MQTT服务器返回数据以后,解析处理MQTT返回的数据

 

 

 

 

 

 

 

 

 

5.如果接收到普通的通信消息,将会调用接收数据回调函数

 

 

 

6.发布消息

只要判断成功连接了MQTT,发送消息的函数可以写到任意地方 .

 

 

 

 

 

 

 

注意事项

 

1.在mqtt.h里面 有一个 mqtt_send_buff_len 500

该变量控制着发送协议的最大长度,用户需要根据自己的情况修改该值.

为防止提取缓存时导致内存溢出,我编写底层的时候设置了默认超过该值的打包协议将被丢弃.

 

 

 

 

 

2.发布消息成功函数只有在消息等级1和消息等级2的时候才会进入

消息等级1和消息等级2服务器只要应答便会进入此函数.说明服务器确实接收到了数据.

 

 

 

 

3.假设自己的网络模块并非透传模式

假设使用的串口2和模块进行的通信

1.发送数据,假设发送66个数据

1.1 首先发送 AT+CIPSEND=66\r\n    66:为要发送的数据个数

1.2 等待模块返回 >

1.3 发送要发送的数据给模块

1.4 模块返回 Recv 66 bytes  

1.5 模块发送完成返回 SEND OK

2.接收数据

2.1 接收数据格式: +IPD,XXXX:真实数据    XXXX 为接收的数据个数

 

修改 mqtt_send_function里面的发送过程

 

 

 

如果接收到 > 清零接收超时

如果 接收到 SEND OK 清零发送超时

 

 

 

接收的数据直接提取有效数据,然后交于 mqtt_read_function函数处理

 

 

 

4.如果内存允许,建议采用下面的方式处理接收数据

 

 

 

5.如果客户发现自己当前的版本和细节介绍的有出入

请用户直接把此节的文件移植替换当前使用的文件

随着时间的推移,我可能会发现并修改完善许多细节

我会尽量做到版本兼容!

如若有不兼容的地方,我将在文件说明中做详细说明.

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

你可能感兴趣的文章
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>