Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Auflösen des Gerätestandorts mithilfe der MQTT-Themen zu AWS IoT Core Device Location
Sie können reservierte MQTT-Themen verwenden, um mit der AWS IoT Core Gerätestandortfunktion die neuesten Standortinformationen für Ihre Geräte abzurufen.
MQTT-Themen zum Format des Gerätestandorts
Für reservierte Themen für den AWS IoT Core Gerätestandort wird das folgende Präfix verwendet:
$aws/device_location/
{customer_device_id}
/
Um ein vollständiges Thema zu erstellen, ersetzen Sie zunächst
durch Ihre eindeutige ID, mit der Sie Ihr Gerät identifizieren. Wir empfehlen, dass Sie das angebencustomer_device_id
WirelessDeviceId
, z. B. für LoRa WAN- und Sidewalk-Geräte, und
, ob Ihr Gerät als AWS IoT Ding registriert ist. Anschließend fügen Sie das Thema mit dem Themenbereich hinzu, z. B. thingName
get_position_estimate
oder get_position_estimate/accepted
, wie im folgenden Abschnitt gezeigt.
Anmerkung
darf nur Buchstaben, Zahlen und Bindestriche enthalten. Wenn Sie Themen zum Gerätestandort abonnieren, können Sie nur das Pluszeichen (+) als Platzhalterzeichen verwenden. Sie können beispielsweise den Platzhalter {customer_device_id}
+
für
verwenden, um die Standortinformationen für Ihre Geräte abzurufen. Wenn Sie das Thema {customer_device_id}
$aws/device_location/
abonnieren, wird eine Nachricht mit den Standortinformationen für Geräte veröffentlicht, die mit einer beliebigen Geräte-ID übereinstimmen, sofern das Problem erfolgreich gelöst wurde.+
/get_position_estimate/accepted
Im Folgenden finden Sie die reservierten Themen, die für die Interaktion mit AWS IoT Core Device Location verwendet werden.
MQTT-Themen zum Gerätestandort | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Thema | Zulässige Operationen | Beschreibung | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Veröffentlichen |
Ein Gerät veröffentlicht zu diesem Thema, um die gescannten Rohmessdaten nach AWS IoT Core Gerätestandort aufzulösen. |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
$aws/device_location/ |
Abonnieren |
AWS IoT Core Der Gerätestandort veröffentlicht die Standortinformationen zu diesem Thema, wenn der Gerätestandort erfolgreich ermittelt wurde. |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Abonnieren |
AWS IoT Core Der Gerätestandort veröffentlicht die Fehlerinformationen zu diesem Thema, wenn der Gerätestandort nicht aufgelöst werden kann. |
Richtlinie für MQTT-Themen zum Gerätestandort
Um Nachrichten zu Themen zum Gerätestandort zu empfangen, muss Ihr Gerät eine Richtlinie verwenden, die es ihm ermöglicht, eine Verbindung zum AWS IoT Gerätegateway herzustellen und die MQTT-Themen zu abonnieren.
Im Folgenden finden Sie ein Beispiel für die Richtlinie, die für den Empfang von Nachrichten zu verschiedenen Themen erforderlich ist.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "iot:Publish" ], "Resource": [ "arn:aws:iot:
region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate" ] }, { "Effect": "Allow", "Action": [ "iot:Receive" ], "Resource": [ "arn:aws:iot:region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate/accepted", "arn:aws:iot:region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate/rejected" ] }, { "Effect": "Allow", "Action": [ "iot:Subscribe" ], "Resource": [ "arn:aws:iot:region
:account
:topicfilter/$aws/device_location/customer_device_id
/get_position_estimate/accepted", "arn:aws:iot:region
:account
:topicfilter/$aws/device_location/customer_device_id
/get_position_estimate/rejected" ] } ] }
Themen zum Gerätestandort und Nutzlast
Im Folgenden werden die Themen AWS IoT Core zum Gerätestandort, das Format ihrer Nachrichtennutzdaten und eine Beispielrichtlinie für jedes Thema beschrieben.
/get_position_estimate
Veröffentlichen Sie eine Nachricht zu diesem Thema, um die Rohmessdaten des Geräts abzurufen und nach AWS IoT Core Gerätestandort aufzulösen.
$aws/device_location/
customer_device_id
/get_position_estimate
AWS IoT Core Device Location antwortet mit der Veröffentlichung entweder auf /get_position_estimate/accepted oder/get_position_estimate/rejected.
Anmerkung
Bei der zu diesem Thema veröffentlichten Nachricht muss es sich um eine gültige JSON-Nutzlast handeln. Wenn die Eingabenachricht kein gültiges JSON-Format hat, erhalten Sie keine Antwort. Weitere Informationen finden Sie unter Nachrichtennutzlast.
Das Format für die Nachrichtennutzlast folgt einer ähnlichen Struktur wie der Hauptteil der API-Operationsanforderung AWS IoT Wireless . GetPositionEstimate
. Sie enthält Folgendes:
-
Eine optionale
Timestamp
-Zeichenfolge, die dem Datum und der Uhrzeit entspricht, an denen der Standort aufgelöst wurde. DieTimestamp
-Zeichenfolge kann eine Mindestlänge von 1 und eine Maximallänge von 10 haben. -
Eine optionale
MessageId
-Zeichenfolge, die verwendet werden kann, um die Anforderung der Antwort zuzuordnen. Wenn Sie diese Zeichenfolge angeben, enthält die Nachricht, die in den Themenget_position_estimate/accepted
oderget_position_estimate/rejected
veröffentlicht wird, dieseMessageId
. DieMessageID
-Zeichenfolge kann eine Mindestlänge von 1 und eine Maximallänge von 256 haben. -
Die Messungsdaten des Geräts, das mindestens einen der folgenden Messungstypen enthält:
Im Folgenden finden Sie ein Beispiel für eine Nachrichtennutzlast.
{ "Timestamp":
"1664313161"
, "MessageId":"ABCD1"
, "WiFiAccessPoints": [ { "MacAddress": "A0:EC:F9:1E:32:C1
", "Rss":-66
} ], "Ip":{ "IpAddress":"54.192.168.0"
}, "Gnss":{ "Payload":"8295A614A2029517F4F77C0A7823B161A6FC57E25183D96535E3689783F6CA48"
, "CaptureTime":1354393948
} }
Im Folgenden finden Sie ein Beispiel für die erforderliche Richtlinie:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "iot:Publish" ], "Resource": [ "arn:aws:iot:
region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate" ] } ] }
/get_position_estimate/accepted
AWS IoT Core Device Location veröffentlicht eine Antwort zu diesem Thema, wenn Sie die aufgelösten Standortinformationen für Ihr Gerät zurücksenden. Die Standortinformationen werden im GeoJSON-Format
$aws/device_location/
customer_device_id
/get_position_estimate/accepted
Im Folgenden werden die Nachrichtennutzlast und ein Beispiel für eine Richtlinie dargestellt.
Im Folgenden sehen Sie ein Beispiel für die Nachrichtennutzlast im GeoJSON-Format. Wenn Sie MessageId
in Ihren Rohmessdaten ein angegeben haben und der AWS IoT Core Gerätestandort die Standortinformationen erfolgreich aufgelöst hat, gibt die Nachrichtennutzlast dieselben MessageId
Informationen zurück.
{ "coordinates": [ 13.37704086303711, 52.51865005493164 ], "type": "Point", "properties": { "verticalAccuracy": 707, "verticalConfidenceLevel": 0.68, "horizontalAccuracy": 389, "horizontalConfidenceLevel": 0.68, "country": "USA", "state": "CA", "city": "Sunnyvalue", "postalCode": "91234", "timestamp": "2022-11-18T14:03:57.391Z", "messageId": "ABCD1" } }
Im Folgenden finden Sie ein Beispiel für die erforderliche Richtlinie:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "iot:Subscribe" ], "Resource": [ "arn:aws:iot:
region
:account
:topicfilter/$aws/device_location/customer_device_id
/get_position_estimate/accepted" ] }, { "Effect": "Allow", "Action": [ "iot:Receive" ], "Resource": [ "arn:aws:iot:region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate/accepted" ] } ] }
/get_position_estimate/rejected
AWS IoT Core Device Location veröffentlicht eine Fehlermeldung zu diesem Thema, wenn der Gerätestandort nicht aufgelöst werden kann.
$aws/device_location/
customer_device_id
/get_position_estimate/rejected
Im Folgenden sehen Sie die Nachrichtennutzlast und ein Beispiel für die Richtlinie. Weitere Informationen zu den Fehlern finden Sie unter Fehlerbehebung beim Auflösen des Standorts.
Im Folgenden finden Sie ein Beispiel für die Nachrichten-Payload, die den Fehlercode und die Meldung enthält, aus der hervorgeht, warum AWS IoT Core Device Location die Standortinformationen nicht auflösen konnte. Wenn Sie MessageId
bei der Bereitstellung Ihrer Rohmessdaten ein angegeben haben und der AWS IoT Core Gerätestandort die Standortinformationen nicht auflösen konnte, werden dieselben MessageId
Informationen in der Nachrichtennutzlast zurückgegeben.
{ "errorCode": 500, "errorMessage":"Internal server error", "messageId": "ABCD1" }
Im Folgenden finden Sie ein Beispiel für die erforderliche Richtlinie:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "iot:Subscribe" ], "Resource": [ "arn:aws:iot:
region
:account
:topicfilter/$aws/device_location/customer_device_id
/get_position_estimate/rejected" ] }, { "Action": [ "iot:Receive" ], "Resource": [ "arn:aws:iot:region
:account
:topic/$aws/device_location/customer_device_id
/get_position_estimate/rejected" ] } ] }