用python的flask写的一个MQTT中转功能,http的方式发送数据和接收数据

需求背景

给一个客户对接人脸识别的设备,最后需要通知服务端进行一些消息推送。

简单例子


# 作者 陈老师
# https://v.iiar.cn
import json
import paho.mqtt.client as mqtt
import requests
from flask import Flask, requestapp = Flask(__name__)# MQTT配置
mq_broker = "127.0.0.1"  # MQTT测试服务器
mq_port = 1883  # 非加密端口
zt = 'ddddd'def http_post(data):url = "http://127.0.0.1:6688/api/user/mqtt_msg"try:res = requests.post(url, json=data)print(res.text)except Exception as e:print(e)# MQTT连接回调函数
def on_connect(client, userdata, flags, rc):if rc == 0:client.subscribe(zt)print("MQTT连接成功")else:print(f"MQTT连接失败,返回码:{rc}")# 处理接收到的MQTT消息
def on_message(client, userdata, msg):mqtt_message = msg.payload.decode()  # 解析MQTT消息print('收到消息', mqtt_message)http_post(json.loads(mqtt_message))# 连接MQTT服务器
mq = mqtt.Client()
mq.on_connect = on_connect
mq.on_message = on_message
mq.connect(mq_broker, mq_port, 60)
# 启动MQTT客户端线程
mq.loop_start()def send_mqtt_msg(text):mq.publish(zt, text)@app.route('/', methods=['POST'])
def index():data = request.jsonprint('给机器发消息', data)t = json.dumps(data)t = json.loads(t)send_mqtt_msg(t)return 'ok'# 调试模式运行
if __name__ == '__main__':# debug=True,app.run(port=6699, host='0.0.0.0')# 安装依赖
# pip install -r requirements.txt# 导出依赖库
# pip freeze > requirements.txt

所需安装拓展

requirements.txt

blinker==1.9.0
certifi==2024.8.30
charset-normalizer==3.4.0
click==8.1.7
Flask==3.1.0
idna==3.10
importlib_metadata==8.5.0
itsdangerous==2.2.0
Jinja2==3.1.4
MarkupSafe==3.0.2
paho-mqtt==2.1.0
requests==2.32.3
urllib3==2.2.3
Werkzeug==3.1.3
zipp==3.21.0

实际应用例子

# 作者 陈老师
# https://v.iiar.cn
import json
from datetime import datetime
import paho.mqtt.client as mqtt
import requests
from flask import Flask, requestapp = Flask(__name__)# MQTT配置
mq_broker = "127.0.0.1"  # MQTT测试服务器
mq_port = 1883  # 非加密端口
sb = '123456789' # 我的设备号
zt = f'fungxi_{sb}_downLink'  # 发给设备
zt2 = f'fungxi_{sb}_upLink'  # 设备上报def http_post(data): # 接收mqtt回调的apiurl = "http://127.0.0.1:6688/api/user/mqtt_msg"try:res = requests.post(url, json=data)print(res.text)except Exception as e:print(e)# MQTT连接回调函数
def on_connect(client, userdata, flags, rc):if rc == 0:client.subscribe(zt)client.subscribe(zt2)print("MQTT连接成功")else:print(f"MQTT连接失败,返回码:{rc}")# 处理接收到的MQTT消息
def on_message(client, userdata, msg):mqtt_message = msg.payload.decode()  # 解析MQTT消息try:data = json.loads(mqtt_message)except json.JSONDecodeError:print("无效的JSON数据")returnif msg.topic == zt:if data['cmd'] == 'heartD':returnprint('发给设备', mqtt_message)elif msg.topic == zt2:if data['cmd'] == 'heartU':bot_heartbeat()returnelif data['cmd'] == 'strangerRecordU':  # 陌生人returnelif data['cmd'] == 'verifiedRecordU':  # 人脸库的# http_post(['data'])check_successfully(data['data'])print('设备上报', mqtt_message)# 连接MQTT服务器
mq = mqtt.Client()
mq.on_connect = on_connect
mq.on_message = on_message
mq.connect(mq_broker, mq_port, 60)
# 启动MQTT客户端线程
mq.loop_start()def send_mqtt_msg(text):mq.publish(zt, text)# 机器返回心跳
def bot_heartbeat():r = {"cmd": "heartD","time": datetime.now().strftime("%Y-%m-%d %H:%M:%S")}t = json.dumps(r)send_mqtt_msg(t)def check_successfully(data):data = data[0]user_id = data['num']  # 用户idname = data['name']  # 用户名img = data['liveImageBase64']  # 扫脸图片verifiedCode = data['verifiedCode']  # 识别状态bot_time = data['time']  # 机器里识别时间personType = data['personType']if personType == '1' and verifiedCode == 0:  # 通过passsend_data = {'user_id': user_id,'name': name,'img': img,'verifiedCode': verifiedCode,'bot_time': bot_time,'personType': personType}# print(bot_time)http_post(send_data)@app.route('/', methods=['POST'])
def index():data = request.jsonprint('给机器发消息', data)t = json.dumps(data)t = json.loads(t)send_mqtt_msg(t)return 'ok'# 调试模式运行
if __name__ == '__main__':# debug=True,app.run(port=6699, host='0.0.0.0')# 安装依赖
# pip install -r requirements.txt# 导出依赖库
# pip freeze > requirements.txt

详细说明文档

由chatGPT整理

中文解释文档

1. 项目简介

该项目实现了一个基于 MQTT 协议和 Flask 框架的应用。它的功能主要包括:

  • 接收来自设备的上报消息(如人脸识别结果、心跳等)。
  • 向设备发送下行指令(如心跳响应等)。
  • 通过HTTP请求将接收到的数据转发到本地服务器进行处理。

该应用集成了 MQTT 客户端库 paho.mqtt.client,用于与设备进行通信,并使用 Flask 框架提供一个HTTP接口,接收外部发送的消息并转发给设备。

2. 主要功能
  1. MQTT通信:

    • 设备通过MQTT协议发送上报消息(如人脸识别结果、心跳等),服务器接收并进行处理。
    • 服务器可以向设备发送下行消息(如心跳响应、命令等)。
  2. HTTP接口:

    • 服务器提供一个HTTP接口(POST /)接收外部请求,通过MQTT协议向设备发送消息。
  3. 人脸识别处理:

    • 设备通过MQTT上报人脸识别结果,服务器将识别结果转发给本地API进行进一步的处理(如存储、通知等)。
3. 主要模块
3.1 MQTT配置
mq_broker = "127.0.0.1"  # MQTT测试服务器
mq_port = 1883  # 非加密端口
sb = '123456789' # 我的设备号
zt = f'fungxi_{sb}_downLink'  # 发给设备
zt2 = f'fungxi_{sb}_upLink'  # 设备上报
  • mq_broker:MQTT服务器的IP地址,用于连接设备。
  • mq_port:MQTT服务器的端口号,使用非加密连接(默认为1883端口)。
  • sb:设备的唯一序列号。
  • zt:发送给设备的消息主题,用于控制设备或向设备发送指令。
  • zt2:设备上报消息的主题,用于接收设备的上报数据(如识别结果)。
3.2 HTTP POST请求
def http_post(data):url = "http://127.0.0.1:6688/api/user/mqtt_msg"  # 本地API接口地址try:res = requests.post(url, json=data)  # 发送POST请求print(res.text)  # 打印服务器响应内容except Exception as e:print(e)  # 打印异常信息
  • http_post(data):这个函数用于将数据通过HTTP POST请求发送到本地的API接口。一般用于将设备上报的数据转发到其他服务进行处理。
3.3 MQTT消息处理
def on_connect(client, userdata, flags, rc):if rc == 0:  # 连接成功client.subscribe(zt)  # 订阅设备下行消息client.subscribe(zt2)  # 订阅设备上行消息print("MQTT连接成功")else:  # 连接失败print(f"MQTT连接失败,返回码:{rc}")
  • on_connect:当MQTT客户端连接成功时,会订阅两个主题:zt(发送给设备)和zt2(设备上报的消息)。
  • on_message:处理接收到的MQTT消息,根据主题分发不同的处理逻辑。
3.4 处理接收到的MQTT消息
def on_message(client, userdata, msg):mqtt_message = msg.payload.decode()  # 解析MQTT消息try:data = json.loads(mqtt_message)  # 将消息转为JSON格式except json.JSONDecodeError:  # 如果无法解析为JSONprint("无效的JSON数据")returnif msg.topic == zt:  # 如果是下行消息if data['cmd'] == 'heartD':  # 如果是心跳消息,直接返回returnprint('发给设备', mqtt_message)elif msg.topic == zt2:  # 如果是设备上报消息if data['cmd'] == 'heartU':  # 如果是设备上报的心跳消息bot_heartbeat()  # 发送机器心跳returnelif data['cmd'] == 'strangerRecordU':  # 陌生人记录returnelif data['cmd'] == 'verifiedRecordU':  # 人脸识别记录check_successfully(data['data'])  # 检查是否识别成功print('设备上报', mqtt_message)
  • on_message:处理接收到的消息,并根据消息的主题和命令类型(如心跳、陌生人记录、人脸识别记录等)执行不同的操作。
3.5 发送MQTT消息
def send_mqtt_msg(text):mq.publish(zt, text)  # 向设备下行主题发送消息
  • send_mqtt_msg:将文本消息通过MQTT协议发送到设备,通常用于向设备发送指令或控制消息。
3.6 心跳响应
def bot_heartbeat():r = {"cmd": "heartD",  # 命令类型:心跳"time": datetime.now().strftime("%Y-%m-%d %H:%M:%S")  # 当前时间}t = json.dumps(r)  # 将数据转换为JSON字符串send_mqtt_msg(t)  # 发送心跳消息
  • bot_heartbeat:当设备向服务器发送心跳时,服务器通过MQTT向设备响应心跳消息,表明设备仍然在线。
3.7 人脸识别结果处理
def check_successfully(data):data = data[0]  # 获取识别结果中的第一条数据user_id = data['num']  # 用户IDname = data['name']  # 用户名img = data['liveImageBase64']  # 扫脸图片的Base64编码verifiedCode = data['verifiedCode']  # 识别状态(0为通过)bot_time = data['time']  # 机器识别的时间personType = data['personType']  # 人员类型(1为已登记用户)if personType == '1' and verifiedCode == 0:  # 如果是已登记用户且识别通过pass  # 这里可以处理已通过的情况# 构造发送数据send_data = {'user_id': user_id,'name': name,'img': img,'verifiedCode': verifiedCode,'bot_time': bot_time,'personType': personType}# 打印识别时间(可用于调试)# print(bot_time)# 发送数据到本地APIhttp_post(send_data)
  • check_successfully:该函数处理设备上报的人脸识别数据,将其解析并将成功的识别结果转发到本地API进行进一步处理。
3.8 Flask HTTP接口
@app.route('/', methods=['POST'])
def index():data = request.json  # 获取请求中的JSON数据print('给机器发消息', data)  # 打印发送给机器的消息t = json.dumps(data)  # 将数据转换为JSON字符串t = json.loads(t)  # 重新解析JSON(这里可以进行进一步的数据处理)send_mqtt_msg(t)  # 发送消息给设备return 'ok'  # 返回成功响应
  • index:这是Flask应用提供的HTTP接口,接收外部的POST请求。请求中的数据会通过MQTT协议转发给设备。
4. 运行说明
  1. 安装依赖
    在项目根目录下创建 requirements.txt 文件,列出项目的依赖库:

    pip install -r requirements.txt
    
  2. 启动服务
    运行Flask应用:

    python app.py
    

    服务器将会监听在 6699 端口上。

  3. 导出依赖
    如果需要将当前环境的依赖导出为 requirements.txt 文件,可以运行:

    pip freeze > requirements.txt
    
5. 总结

该项目主要通过MQTT协议与设备进行实时通信,通过Flask框架提供一个HTTP接口接收外部请求并转发给设备。它主要应用于设备控制、实时数据处理和系统集成等场景。

延伸了解

这种基于 MQTT 协议和 Flask 框架的系统,通常会应用于需要实时设备控制、数据收集和状态反馈的场景。以下是一些典型的应用场景:

1. 智能门禁系统

在智能门禁系统中,设备(如门禁机、门锁等)可能需要通过人脸识别来判断是否允许某人进入。设备通过MQTT协议将人脸识别结果(例如是否识别成功、人员身份等)上报到服务器,服务器根据识别结果进行处理,并反馈给设备是否允许打开门锁。

  • 设备角色:门禁设备、门锁、门禁卡读卡器、人脸识别摄像头等。
  • 系统需求
    • 设备上报用户识别数据(如人脸识别结果、时间戳等)。
    • 系统根据识别结果决定是否打开门锁。
    • 系统向设备发送状态更新(如心跳包、设备状态监控等)。

使用场景

  • 办公楼、住宅小区、公共场所等的智能门禁控制。
  • 企业考勤系统,自动记录员工进出。

2. 智能监控与安防

在智能监控系统中,摄像头、传感器等设备可能会使用人脸识别、动作检测等技术监控环境。当发现可疑人物或异常行为时,设备会通过MQTT协议将监控数据上传至服务器,服务器进行处理(如报警、记录日志等),并根据规则发送指令给设备(如开启警报、录像等)。

  • 设备角色:摄像头、传感器、警报器、录像设备等。
  • 系统需求
    • 实时接收设备的监控数据或报警信号。
    • 根据设备上报的结果,向设备发送指令(如触发警报、录像等)。
    • 与外部系统(如安防公司、移动端APP等)集成,进行信息转发或展示。

使用场景

  • 智能家居安防系统,监控家庭安全。
  • 企业或公共场所的智能安防系统,防盗、监控等。

3. 智能家居系统

在智能家居场景中,设备之间的交互和控制通常通过MQTT协议实现。例如,用户通过手机APP控制家里的智能灯泡、空调、门锁等设备,设备将状态更新上报到服务器,服务器再根据控制指令下发新的状态更新给设备。

  • 设备角色:智能灯泡、空调、窗帘、智能插座、门锁等。
  • 系统需求
    • 设备实时上报状态(如温度、湿度、是否开锁、是否开灯等)。
    • 用户通过手机APP发送控制指令(如开关灯、调节空调温度等)。
    • 系统根据用户指令向设备发送MQTT消息进行控制。

使用场景

  • 智能家居控制系统,用户通过手机控制家居设备。
  • 智能办公环境,自动调节温度、照明等。

4. 远程医疗与健康监测

在医疗设备或健康监测系统中,传感器(如心率监测仪、血压计、体温计等)通过MQTT将患者的健康数据实时上传到服务器,服务器将数据存储并进行分析,同时向设备发送指令进行实时干预(例如在心率异常时提醒设备报警)。

  • 设备角色:健康监测设备、传感器、智能手表等。
  • 系统需求
    • 设备上报患者的实时健康数据(如心率、血压、体温等)。
    • 系统根据数据分析,给设备发送指令(如报警、记录日志等)。
    • 数据存储与远程监控,医生或护理人员可以实时查看患者状态。

使用场景

  • 老年人健康监护,实时监测老年人的身体状况。
  • 慢性病患者的远程健康管理。

5. 工业物联网(IIoT)

在工业物联网(IIoT)应用中,传感器和设备需要实时监控生产线或设备的状态,例如温度、压力、湿度、运行速度等数据。这些设备通过MQTT协议上传状态数据,服务器根据数据进行故障预警、生产调度等。

  • 设备角色:工业传感器、监控设备、生产机器、自动化设备等。
  • 系统需求
    • 设备实时上报生产数据(如设备运行状态、温度、湿度等)。
    • 系统根据设备数据进行状态监控,发现异常时发出报警指令。
    • 向设备发送控制指令(如调整温度、改变生产参数等)。

使用场景

  • 工厂自动化,实时监控生产线设备的运行状态。
  • 智能制造,优化生产流程,减少故障率。

6. 智慧停车系统

在智慧停车系统中,停车场的入口、出口、车位传感器等设备通过MQTT协议上传实时的停车数据。例如,设备上报车辆进出情况、空闲车位数等,系统根据这些信息提供停车导航、收费结算等服务。

  • 设备角色:停车场摄像头、车位传感器、停车收费机等。
  • 系统需求
    • 设备上报实时停车数据(如车位是否空闲、车辆进出时间等)。
    • 系统根据数据向用户提供停车位信息、导航指引。
    • 向设备发送指令进行车位管理或收费操作。

使用场景

  • 智慧停车场,实时监控停车位使用情况。
  • 城市交通管理,优化停车资源利用。

7. 智能农业与环境监测

在智能农业和环境监测系统中,设备(如土壤湿度传感器、气象站、灌溉系统等)通过MQTT协议实时上传环境数据,系统根据数据分析向设备发送指令(如启动灌溉、调整温室温度等)。

  • 设备角色:土壤湿度传感器、温度传感器、气象站、自动化灌溉系统等。
  • 系统需求
    • 设备上报环境数据(如温度、湿度、土壤湿度等)。
    • 系统根据数据自动调整设备参数(如启动灌溉、调节温湿度等)。
    • 数据存储与远程监控,农业管理人员可以随时查看环境数据。

使用场景

  • 智能温室,自动调节温湿度,控制灌溉系统。
  • 智能农场,精准农业,减少水资源浪费。

总结

这种需求主要出现在那些 需要实时监控、数据收集、设备控制与反馈的场景。利用MQTT协议和Flask框架实现的系统能够高效地处理设备之间的消息传递和数据流转。典型的应用场景包括:

  • 智能门禁与考勤系统
  • 智能安防与监控
  • 智能家居控制
  • 远程医疗健康监测
  • 工业物联网(IIoT)
  • 智慧停车与交通管理
  • 智能农业与环境监测

这些场景都涉及到设备与服务器之间的高效通信、状态反馈和远程控制,且对于实时性、稳定性和可扩展性有较高的要求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/62971.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ASP.NET |日常开发中读写XML详解

ASP.NET |日常开发中读写XML详解 前言一、XML 概述1.1 定义和结构1.2 应用场景 二、读取 XML 文件2.1 使用XmlDocument类(DOM 方式)2.2 使用XmlReader类(流方式) 三、写入 XML 文件3.1 使用XmlDocument类3.2 使用XmlWr…

分布式 Paxos算法 总结

前言 相关系列 《分布式 & 目录》《分布式 & Paxos算法 & 总结》《分布式 & Paxos算法 & 问题》 参考文献 《图解超难理解的 Paxos 算法(含伪代码)》《【超详细】分布式一致性协议 - Paxos》 Basic-Paxos 基础帕克索斯算法…

Git-基础操作命令

目录 Git基础操作命令 case *查看提交日志 log 版本回退 get add . Git基础操作命令 我们创建并且初始化这个仓库以后,我们就要在里面进行操作。 Git 对于文件的增删改查存在几个状态,这些修改状态会随着我们执行Git的命令而发生变化。 untracked、…

Spring Boot 实战:构建一个社交平台 API

在这篇博客中,我们将继续深入 Spring Boot 的开发实践,通过构建一个简单的社交平台 API,帮助大家理解如何使用 Spring Boot 高效地开发一个具有注册、登录、个人资料管理、帖子发布与评论、点赞等功能的社交平台。在开发过程中,我…

配置mysqld(读取选项内容,基本配置),数据目录(配置的必要性,目录下的内容,具体文件介绍,修改配置)

目录 配置mysqld 读取选项内容 介绍 启动脚本 基本配置 内容 端口号 数据目录的路径 配置的必要性 配置路径 mysql数据目录 具体文件 修改配置时 权限问题 配置mysqld 读取选项内容 介绍 会从[mysqld] / [server] 节点中读取选项内容 优先读取[server] 虽然服务…

智能家居WTR096-16S录放音芯片方案,实现语音播报提示及录音留言功能

前言: 在当今社会的高速运转之下,夜幕低垂之时,许多辛勤工作的父母尚未归家。对于肩负家庭责任的他们而言,确保孩童按时用餐与居家安全成为心头大事。此时,家居留言录音提示功能应运而生,恰似家中的一位无形…

Java 编程基础:开启编程世界的大门

一、Java 环境搭建 在开始编写 Java 代码之前,我们需要先搭建 Java 开发环境。 1. 安装 JDK(Java Development Kit) JDK 是 Java 开发的核心工具包,它包含了编译 Java 源文件所需的编译器(javac)以及运行…

pytorch bilstm crf的教程,注意 这里不支持批处理,要支持批处理 用torchcrf这个。

### Bi-LSTM Conditional Random Field ### pytorch tutorials https://pytorch.org/tutorials/beginner/nlp/advanced_tutorial.html ### 模型主要结构: ![title](sources/bilstm.png) pytorch bilstm crf的教程,注意 这里不支持批处理 Python version…

【SickOs1.1靶场渗透】

文章目录 一、基础信息 二、信息收集 三、反弹shell 四、提权 一、基础信息 Kali IP:192.168.20.146 靶机IP:192.168.20.150 二、信息收集 端口扫描 nmap -sS -sV -p- -A 192.168.20.150 开放了22、3128端口,8080端口显示关闭 22端…

【HF设计模式】03-装饰者模式

声明:仅为个人学习总结,还请批判性查看,如有不同观点,欢迎交流。 摘要 《Head First设计模式》第3章笔记:结合示例应用和代码,介绍装饰者模式,包括遇到的问题、遵循的 OO 原则、达到的效果。 …

Mysql数据库中,什么情况下设置了索引但无法使用?

在MySQL数据库中,即使已经正确设置了索引,但在某些情况下索引可能无法被使用。 以下是一些常见的情况: 1. 数据分布不均匀 当某个列的数据分布非常不均匀时,索引可能无法有效地过滤掉大部分的数据,导致索引失效。 …

秒杀业务中的库存扣减为什么不加分布式锁?

前言 说到秒杀业务的库存扣减,就还是得先确认我们的扣减基本方案。 秒杀场景的库存扣减方案 一般的做法是,先在Redis中做扣减,然后发送一个MQ消息,消费者在接到消息之后做数据库中库存的真正扣减及业务逻辑操作。 如何解决数据…

ChatGPT生成测试用例的最佳实践(一)

前面介绍的案例主要展示了ChatGPT在功能、安全和性能测试用例生成方面的应用和成果。通过ChatGPT生成测试用例,测试团队不仅可以提升工作效率,还可以加快测试工作的速度,尽早发现被测系统中的问题。问题及早发现有助于提高软件的质量和用户满…

基于Redis实现令牌桶算法

基于Redis实现令牌桶算法 令牌桶算法算法流程图优点缺点 实现其它限流算法 令牌桶算法 令牌桶是一种用于分组交换和电信网络的算法。它可用于检查数据包形式的数据传输是否符合定义的带宽和突发性限制(流量不均匀或变化的衡量标准)。它还可以用作调度算…

操作系统(8)死锁

一、概念 死锁是指在一个进程集合中的每个进程都在等待只能由该集合中的其他进程才能引起的事件,而无限期地僵持下去的局面。在多任务环境中,由于资源分配不当,导致两个或多个进程在等待对方释放资源时陷入无限等待的状态,这就是死…

Micropython 扩展C模块<HelloWorld>

开发环境 MCU:Pico1(无wifi版)使用固件:自编译版本开发环境:MacBook Pro Sonoma 14.5开发工具:Thonny 4.1.6开发语言:MicroPython 1.24 执行示例 在github上获取micropython,我使…

并查集基础

abstract 并查集(Union-Find Set)是一种数据结构,主要用于处理动态连通性问题(Dynamic Connectivity Problem),例如在图论中判断两点是否属于同一个连通分量,以及动态地合并集合。 它广泛应用…

CloudberryDB(一)安装部署多节点分布式数据库集群

CloudberryDB: 一个 Greenplum Database 分布式数据库开源版本的衍生项目, 针对开源 Greenplum Database 优化的地方, CloudberryDB制定了路线图(https://github.com/orgs/cloudberrydb/discussions/369)并在逐步改…

解决Logitech G hub 无法进入一直转圈的方案(2024.12)

如果你不是最新版本无法加载尝试以下方案:删除AppData 文件夹下的logihub文件夹 具体路径:用户名根据实际你的请情况修改 C:\Users\Administrator\AppData\Local 如果你有通过lua编译脚本,记得备份!! ↓如果你是最新…

数据库范式与反范式化:如何权衡性能与数据一致性

目录 1. 什么是数据库范式(Normalization)?第一范式(1NF)第二范式(2NF)第三范式(3NF) 2. 什么是反范式化(Denormalization)?3. 反范式…