Ich versuche, mit Azure IoT-Hub mit MQTT zu verbinden und Nachrichten zu senden und zu empfangen.Python paho-MQTT-Verbindung mit azurem IoT-Hub
Ich verfolge die offizielle Dokumentation gegeben here
Aber es immer mit Code die Verbindung unterbrochen wird: 1, obwohl sie nie in der on_connect Funktion geht. Aber wenn ich versuche, es außerhalb der Funktionen (die auskommentierte Zeile nach der Verbindungszeichenfolge) zu veröffentlichen, geht es in die Methode on_publish.
Die deivce ich hier bin mit einem simulierten Gerät, das ich in der Azure IoT Suite erstellt
Hier wird der Code I
from paho.mqtt import client as mqtt
def on_connect(client, userdata, flags, rc):
print "Connected with result code: %s" % rc
client.subscribe("devices/MyTestDevice02/messages/devicebound/#")
client.publish("devices/MyTestDevice02/messages/events", "Hello World!")
def on_disconnect(client, userdata, rc):
print "Disconnected with result code: %s" % rc
def on_message(client, userdata, msg):
print " - ".join((msg.topic, str(msg.payload)))
client.publish("devices/MyTestDevice02/messages/events", "REPLY", qos=1)
def on_publish(client, userdata, mid):
print "Sent message"
client = mqtt.Client("MyTestDevice02", mqtt.MQTTv311)
client.on_connect = on_connect
client.on_disconnect = on_disconnect
client.on_message = on_message
client.on_publish = on_publish
client.username_pw_set(username="USERNAME.azure-devices.net/MyTestDevice02",
password="SharedAccessSignature=SharedAccessSignature sr=USERNAME.azure-devices.net%2fdevices%2fMyTestDevice02&sig=xxxxxx5rRr7c%3d&se=1492318301")
client.tls_insecure_set(True) # You can also set the proper certificate using client.tls_set()
client.connect("USERNAME.azure-devices.net", port=8883)
#client.publish("devices/MyTestDevice02/messages/events", "Hello World!")
client.loop_forever()
bin mit Jeder Hilfe sehr geschätzt wird. Und ich möchte nicht die SDK verwenden, weshalb ich versuche, es direkt zu veröffentlichen.
Vielen Dank, aber ich kann die CA-Zertifikate nicht finden. Können Sie mich bitte durch den Prozess führen, oder Link sein, der es erklärt. – aladeen
Ich habe das Zertifikat mit meinem Azure-Abonnement erstellt und verknüpft, nachdem ich dieses [link] (https://www.veritas.com/support/de_DE/article.TECH217325) Und in der tls_set() habe ich den Pfad angegeben der Ort des Zertifikats in meinem lokalen Rechner und es wirft den Fehler "Zertifikat Überprüfung fehlgeschlagen" – aladeen