python 没有收到 paho 客户端 MQTT 订阅者

python paho client MQTT subscriber not getting

我正在使用 python Paho 客户端。

我正在将其用于我的功能。

我的代码正在显示

import paho.mqtt.client as mqtt
import time, logging


broker = "127.0.0.1"

port = 1883
QOS = 0

CLEAN_SESSION = True
# error logging


# use DEBUG,INFO,WARNING
def on_subscribe(client, userdata, mid, granted_qos):  # create function for callback
    # print("subscribed with qos",granted_qos, "\n")
    time.sleep(1)
    print("sub acknowledge message id=" + str(mid))
    pass


def on_disconnect(client, userdata, rc=0):
    print("DisConnected result code " + str(rc))


def on_connect(client, userdata, flags, rc):
    print("Connected flags" + str(flags) + "result code " + str(rc))


def on_message(client, userdata, message):
    msg = str(message.payload.decode("utf-8"))
    print("message received in mqtt_subscriber  " + msg)


def on_publish(client, userdata, mid):
    print("message published " + str(mid))


topic1 = "test"
client = mqtt.Client("RDAresp", False)  # create client object

client.on_subscribe = on_subscribe  # assign function to callback
client.on_disconnect = on_disconnect  # assign function to callback
client.on_connect = on_connect  # assign function to callback
client.on_message = on_message
client.connect(broker, port)  # establish connection
time.sleep(1)
client.loop_start()
client.subscribe("RemoteDoorAccess")
count = 1
while True:  # runs forever break with CTRL+C
    print("publishing on topic ", topic1)
    msg = "message : RemoteDoorAccess_resp is published "
    client.publish(topic1, msg)
    count += 1
    time.sleep(5)

并在 views.py

def on_message(client, userdata, message):
    msg = str(message.payload.decode("utf-8"))
    print("message  authority resp module  " + msg)


def on_subscribe(client, userdata, mid, granted_qos):  # create function for callback
    print("subscribed with qos", granted_qos, "\n")
    time.sleep(1)

    pass


def on_disconnect(client, userdata, rc=0):
    print("DisConnected result code " + str(rc))


def on_connect(client, userdata, flags, rc):
    print("Connected flags" + str(flags) + "result code " + str(rc))


def on_publish(client, userdata, mid):
    print("message published " + str(mid))


def mqttConnection():
    topic = "RemoteDoorAccess"
    client = mqtt.Client("RDA", False)  # create client object

    client.on_subscribe = on_subscribe  # assign function to callback
    client.on_disconnect = on_disconnect  # assign function to callback
    client.on_connect = on_connect  # assign function to callback
    client.on_message = on_message
    client.connect(broker, port)  # establish connection
    time.sleep(1)
    client.subscribe("test")
    time.sleep(1)
    print("publishing on topic ", topic)
    msg = "RemoteDoor Access published"
    client.publish(topic, msg)
    time.sleep(10)

@api_view(['GET'])
@permission_classes([])
def remotedooraccess_mobile(request):
        mqttConnection()
        return Response({msg: validation["FDP34"]}, status=status.HTTP_200_OK)

此处主题 'test' 已发布但未订阅。

请检查视图输出

在我的views.py中on_message函数没有被题目测试调用。 我该如何解决这个问题。 我完全被困在这里.. view.py 订阅函数没有调用。

我是 mqtt 的新手。 请帮忙

您需要在 views.py 代码中启动客户端循环,否则实际上 运行 您的 on_message() 回调没有任何意义。

您还应该将对 client.subscribe() 的所有调用移至 on_connect 回调中,并移除对 time.sleep()

的大部分调用