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.
Tutorial: Erstellen eines benutzerdefinierten Autorisierers für AWS IoT Core
Dieses Tutorial zeigt die Schritte zum Erstellen, Validieren und Verwenden einer benutzerdefinierten Authentifizierung mithilfe von AWS CLI. Optional können Sie mithilfe dieses Tutorials Postman verwenden, um Daten mithilfe AWS IoT Core von Publish an zu senden. HTTP API
In diesem Tutorial erfahren Sie, wie Sie eine exemplarische Lambda-Funktion erstellen, die die Autorisierungs- und Authentifizierungslogik implementiert, und einen benutzerdefinierten Autorisierer mithilfe des create-authorizer-Aufrufs mit aktivierter Tokensignatur. Der Autorisierer wird dann mit dem validierttest-invoke-authorizer, und schließlich können Sie Daten an senden, AWS IoT Core indem Sie das HTTP MQTT Testthema Publizieren API verwenden. In der Beispielanforderung wird angegeben, welcher Autorisierer mithilfe des Headers aufgerufen werden soll, und die x-amz-customauthorizer-name
Anforderungsheader werden übergeben. token-key-name x-amz-customauthorizer-signature
Was Sie in diesem Tutorial lernen werden:
So erstellen Sie eine Lambda-Funktion als benutzerdefinierten Autorisierer-Handler
Wie erstelle ich einen benutzerdefinierten Autorisierer mit aktivierter Tokensignatur AWS CLI
So testen Sie Ihren benutzerdefinierten Autorisierer mit dem Befehl test-invoke-authorizer
So veröffentlichen Sie ein MQTT Thema mithilfe von Postman
und validieren die Anfrage mit Ihrem benutzerdefinierten Autorisierer
Für dieses Tutorial brauchen Sie ungefähr 60 Minuten.
In diesem Tutorial führen Sie die folgenden Aktivitäten durch:
- Schritt 1: Erstellen einer Lambda-Funktion für Ihren benutzerdefinierten Autorisierer
- Schritt 2: Erstellen eines öffentlichen und eines privaten Schlüsselpaars für Ihren benutzerdefinierten Autorisierer
- Schritt 3: Erstellen Sie eine benutzerdefinierte Autorisierungsressource und deren Autorisierung
- Schritt 4: Testen Sie den Authorizer, indem Sie ihn anrufen test-invoke-authorizer
- Schritt 5: Testen Sie das Veröffentlichen von MQTT Nachrichten mit Postman
- Schritt 6: Nachrichten im MQTT Testclient anzeigen
- Schritt 7: Überprüfen der Ergebnisse und die nächsten Schritte
- Schritt 8: Bereinigen
Stellen Sie vor Beginn dieses Tutorials sicher, dass Sie über Folgendes verfügen:
-
Einrichten AWS-Konto
Sie benötigen Ihre AWS IoT Handkonsole AWS-Konto , um dieses Tutorial abzuschließen.
Das Konto, das Sie für dieses Tutorial verwenden, funktioniert am besten, wenn es mindestens die folgenden AWS -verwalteten Richtlinien umfasst:
Wichtig
Die in diesem Tutorial verwendeten IAM Richtlinien sind toleranter, als Sie sie in einer Produktionsimplementierung befolgen sollten. Stellen Sie in einer Produktionsumgebung sicher, dass Ihre Konto- und Ressourcenrichtlinien nur die erforderlichen Berechtigungen gewähren.
Wenn Sie IAM Richtlinien für die Produktion erstellen, legen Sie fest, welchen Zugriff Benutzer und Rollen benötigen, und entwerfen Sie dann die Richtlinien, die es ihnen ermöglichen, nur diese Aufgaben auszuführen.
Weitere Informationen finden Sie unter Bewährte Sicherheitsmethoden in IAM
-
Installiert AWS CLI
Informationen zur Installation von finden Sie AWS CLI unter Installation von AWS CLI. Für dieses Tutorial ist AWS CLI Version
aws-cli/2.1.3 Python/3.7.4 Darwin/18.7.0 exe/x86_64
oder höher erforderlich. -
SSLTools öffnen
Die Beispiele in diesem Tutorial verwenden Libre SSL 2.6.5
. Sie können für dieses Tutorial auch die Tools von Open SSL v1.1.1i verwenden. -
AWS Lambda Übersicht überprüft
Wenn Sie Lambda noch nicht verwendet AWS Lambda haben, lesen Sie AWS Lambdaund Erste Schritte mit Lambda, um sich mit den Begriffen und Konzepten vertraut zu machen.
-
Es wurde überprüft, wie Anfragen in Postman erstellt werden.
Weitere Informationen finden Sie unter Erstellen von Anfragen
. -
Benutzerdefinierte Autorisierer wurden aus dem vorherigen Tutorial entfernt.
Sie AWS-Konto können nur eine begrenzte Anzahl von benutzerdefinierten Autorisierern gleichzeitig konfigurieren. Weitere Informationen zum Erstellen eines benutzerdefinierten Autorisierers finden Sie unter Schritt 8: Bereinigen.
Schritt 1: Erstellen einer Lambda-Funktion für Ihren benutzerdefinierten Autorisierer
Die benutzerdefinierte Authentifizierung in AWS IoT Core verwendet Autorisierungsressourcen, die Sie zur Authentifizierung und Autorisierung von Clients erstellen. Die Funktion, die Sie in diesem Abschnitt erstellen, authentifiziert und autorisiert Clients, wenn sie sich mit Ressourcen verbinden und auf sie zugreifen. AWS IoT Core AWS IoT
Die Lambda-Funktion bewirkt Folgendes:
-
Wenn eine Anfrage von kommttest-invoke-authorizer, gibt sie eine IAM Richtlinie mit einer
Deny
Aktion zurück. -
Wenn eine Anfrage von Postman kommt HTTP und der
actionToken
Parameter den Wert von hatallow
, wird eine IAM Richtlinie mit einerAllow
Aktion zurückgegeben. Andernfalls wird eine IAM Richtlinie mit einerDeny
Aktion zurückgegeben.
So erstellen Sie die Lambda-Funktion für Ihren benutzerdefinierten Autorisierer
-
Öffnen Sie auf der Lambda
-Konsole die Option Funktionen . -
Wählen Sie Funktion erstellen.
-
Bestätigen Sie, dass Ohne Vorgabe erstellen ausgewählt ist.
-
Unter Grundlegende Informationen:
-
Geben Sie unter Funktionsname
custom-auth-function
ein. -
Bestätigen Sie unter Laufzeit Node.js 18.x
-
-
Wählen Sie Funktion erstellen aus.
Lambda erstellt eine Node.js-Funktion und eine Ausführungsrolle, die der Funktion die Berechtigung zum Hochladen von Protokollen gewährt. Die Lambda-Funktion übernimmt die Ausführungsrolle, wenn Sie Ihre Funktion aufrufen, und verwendet die Ausführungsrolle, um Anmeldeinformationen für die zu erstellen AWS SDK und Daten aus Ereignisquellen zu lesen.
-
Um den Code und die Konfiguration der Funktion im AWS Cloud9Editor zu sehen, wählen Sie custom-auth-functionim Designerfenster und dann im Navigationsbereich des Editors die Option index.js aus.
Für Skriptsprachen wie Node.js enthält Lambda eine grundlegende Funktion, die eine Erfolgsantwort zurückgibt. Sie können den AWS Cloud9-Editor verwenden, um Ihre Funktion zu bearbeiten, solange Ihr Quellcode nicht größer als 3 MB ist.
-
Ersetzen Sie den Code index.js im Editor durch den folgenden Code:
// A simple Lambda function for an authorizer. It demonstrates // How to parse a CLI and Http password to generate a response. export const handler = async (event, context, callback) => { //Http parameter to initiate allow/deny request const HTTP_PARAM_NAME='actionToken'; const ALLOW_ACTION = 'Allow'; const DENY_ACTION = 'Deny'; //Event data passed to Lambda function var event_str = JSON.stringify(event); console.log('Complete event :'+ event_str); //Read protocolData from the event json passed to Lambda function var protocolData = event.protocolData; console.log('protocolData value---> ' + protocolData); //Get the dynamic account ID from function's ARN to be used // as full resource for IAM policy var ACCOUNT_ID = context.invokedFunctionArn.split(":")[4]; console.log("ACCOUNT_ID---"+ACCOUNT_ID); //Get the dynamic region from function's ARN to be used // as full resource for IAM policy var REGION = context.invokedFunctionArn.split(":")[3]; console.log("REGION---"+REGION); //protocolData data will be undefined if testing is done via CLI. // This will help to test the set up. if (protocolData === undefined) { //If CLI testing, pass deny action as this is for testing purpose only. console.log('Using the test-invoke-authorizer cli for testing only'); callback(null, generateAuthResponse(DENY_ACTION,ACCOUNT_ID,REGION)); } else{ //Http Testing from Postman //Get the query string from the request var queryString = event.protocolData.http.queryString; console.log('queryString values -- ' + queryString); /* global URLSearchParams */ const params = new URLSearchParams(queryString); var action = params.get(HTTP_PARAM_NAME); if(action!=null && action.toLowerCase() === 'allow'){ callback(null, generateAuthResponse(ALLOW_ACTION,ACCOUNT_ID,REGION)); }else{ callback(null, generateAuthResponse(DENY_ACTION,ACCOUNT_ID,REGION)); } } }; // Helper function to generate the authorization IAM response. var generateAuthResponse = function(effect,ACCOUNT_ID,REGION) { var full_resource = "arn:aws:iot:"+ REGION + ":" + ACCOUNT_ID + ":*"; console.log("full_resource---"+full_resource); var authResponse = {}; authResponse.isAuthenticated = true; authResponse.principalId = 'principalId'; var policyDocument = {}; policyDocument.Version = '2012-10-17'; policyDocument.Statement = []; var statement = {}; statement.Action = 'iot:*'; statement.Effect = effect; statement.Resource = full_resource; policyDocument.Statement[0] = statement; authResponse.policyDocuments = [policyDocument]; authResponse.disconnectAfterInSeconds = 3600; authResponse.refreshAfterInSeconds = 600; console.log('custom auth policy function called from http'); console.log('authResponse --> ' + JSON.stringify(authResponse)); console.log(authResponse.policyDocuments[0]); return authResponse; }
-
Wählen Sie Bereitstellen.
-
Nachdem Änderungen bereitgestellt über dem Editor angezeigt wird:
-
Scrollen Sie zum Abschnitt Funktionsübersicht über dem Editor.
-
Kopieren Sie die Funktion ARN und speichern Sie sie, um sie später in diesem Tutorial zu verwenden.
-
-
Testen Sie Ihre Funktion.
-
Wählen Sie die Registerkarte Test.
-
Wählen Sie unter Verwendung der Standard-Testeinstellungen Aufrufen.
-
Wenn der Test erfolgreich war, öffnen Sie in den Ausführungsergebnissen die Ansicht Details. Sie sollten das Richtliniendokument sehen, das die Funktion zurückgegeben hat.
Wenn der Test fehlgeschlagen ist oder Sie kein Richtliniendokument finden, überprüfen Sie den Code, um die Fehler zu finden und zu korrigieren.
-
Schritt 2: Erstellen eines öffentlichen und eines privaten Schlüsselpaars für Ihren benutzerdefinierten Autorisierer
Ihr benutzerdefinierter Autorisierer benötigt für seine Authentifizierung einen öffentlichen und einen privaten Schlüssel. Die Befehle in diesem Abschnitt verwenden Open SSL Tools, um dieses key pair zu erstellen.
So erstellen Sie das Paar aus öffentlichem und privatem Schlüssel für Ihren benutzerdefinierten Autorisierer
-
Erstellen Sie die Datei mit dem privaten Schlüssel.
openssl genrsa -out private-key.pem 4096
-
Überprüfen Sie den Speicherort der Datei mit dem privaten Schlüssel, die Sie gerade erstellt haben.
openssl rsa -check -in private-key.pem -noout
Wenn der Befehl keine Fehler anzeigt, ist die Datei mit dem privaten Schlüssel gültig.
-
Erstellen Sie die Datei mit dem öffentlichen Schlüssel.
openssl rsa -in private-key.pem -pubout -out public-key.pem
-
Überprüfen Sie die Datei mit dem öffentlichen Schlüssel.
openssl pkey -inform PEM -pubin -in public-key.pem -noout
Wenn der Befehl keine Fehler anzeigt, ist die Datei mit dem öffentlichen Schlüssel gültig.
Schritt 3: Erstellen Sie eine benutzerdefinierte Autorisierungsressource und deren Autorisierung
Der AWS IoT benutzerdefinierte Autorisierer ist die Ressource, die alle in den vorherigen Schritten erstellten Elemente zusammenfasst. In diesem Abschnitt erstellen Sie eine benutzerdefinierte Autorisierer-Ressource und erteilen ihr die Erlaubnis, die zuvor erstellte Lambda-Funktion auszuführen. Sie können eine benutzerdefinierte Autorisierungsressource erstellen, indem Sie die AWS IoT Konsole AWS CLI, den oder den verwenden. AWS API
Für dieses Tutorial müssen Sie nur einen benutzerdefinierten Autorisierer erstellen. In diesem Abschnitt wird beschrieben, wie Sie mithilfe der AWS IoT Konsole und der erstellen AWS CLI, sodass Sie die Methode verwenden können, die für Sie am bequemsten ist. Es gibt keinen Unterschied zwischen den mithilfe dieser beiden Methoden erstellen benutzerdefinierten Autorisierer-Ressourcen.
Erstellen Sie eine benutzerdefinierte Authorizer-Ressource
Wählen Sie eine dieser Optionen, um Ihre benutzerdefinierte Autorisierer-Ressource zu erstellen.
So erstellen Sie einen benutzerdefinierten Autorisierer (Konsole)
-
Öffnen Sie die Seite Benutzerdefinierter Autorisierer der AWS IoT Konsole
und wählen Sie Create Authorizer aus. -
In Autorisierer erstellen:
-
Geben Sie in das Feld Autorisierer-Name
my-new-authorizer
ein. -
Markieren Sie unter Autorisierer-Status die Option Aktiv.
-
Wählen Sie in der Autorisierer-Funktion die Lambda-Funktion aus, die Sie zuvor erstellt haben.
-
Unter Token-Validierung – optional:
-
Aktivieren Sie die Token-Validierung.
-
Geben Sie
tokenKeyName
in das Feld Token-Schlüsselname ein. -
Wählen Sie Schlüssel hinzufügen.
-
Geben Sie unter Schlüsselname
FirstKey
ein. -
Geben Sie in das Feld Öffentlicher Schlüssel den Inhalt der Datei
public-key.pem
ein. Achten Sie darauf, die Zeilen aus der Datei mit-----BEGIN PUBLIC KEY-----
und-----END PUBLIC KEY-----
einzuschließen und dem Inhalt der Datei keine Zeilenvorschübe, Zeilenumbrüche oder andere Zeichen hinzuzufügen oder aus ihm zu entfernen. Die Zeichenfolge, die Sie eingeben, sollte in etwa wie im folgenden Beispiel aussehen.-----BEGIN PUBLIC KEY----- MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAvEBzOk4vhN+3LgslvEWt sLCqNmt5Damas3bmiTRvq2gjRJ6KXGTGQChqArAJwL1a9dkS9+maaXC3vc6xzx9z QPu/vQOe5tyzz1MsKdmtFGxMqQ3qjEXAMPLEOmqyUKPP5mff58k6ePSfXAnzBH0q lg2HioefrpU5OSAnpuRAjYKofKjbc2Vrn6N2G7hV+IfTBvCElf0csalS/Rk4phD5 oa4Y0GHISRnevypg5C8n9Rrz91PWGqP6M/q5DNJJXjMyleG92hQgu1N696bn5Dw8 FhedszFa6b2x6xrItZFzewNQkPMLMFhNrQIIyvshtT/F1LVCS5+v8AQ8UGGDfZmv QeqAMAF7WgagDMXcfgKSVU8yid2sIm56qsCLMvD2Sq8Lgzpey9N5ON1o1Cvldwvc KrJJtgwW6hVqRGuShnownLpgG86M6neZ5sRMbVNZO8OzcobLngJ0Ibw9KkcUdklW gvZ6HEJqBY2XE70iEXAMPLETPHzhqvK6Ei1HGxpHsXx6BNft582J1VpgYjXha8oa /NN7l7Zbj/euAb41IVtmX8JrD9z613d1iM5L8HluJlUzn62Q+VeNV2tdA7MfPfMC 8btGYladFAnitThaz6+F0VSBJPu7pZQoLnqyEp5zLMtF+kFl2yOBmGAP0RBivRd9 JWBUCG0bqcLQPeQyjbXSOfUCAwEAAQ== -----END PUBLIC KEY-----
-
-
-
Wählen Sie Autorisierer erstellen.
-
Wenn die benutzerdefinierte Autorisierer-Ressource erstellt wurde, wird die Liste der benutzerdefinierten Autorisierer angezeigt und Ihr neuer benutzerdefinierter Autorisierer sollte in der Liste angezeigt werden. Sie können dann mit dem nächsten Abschnitt fortfahren, um ihn zu testen.
Wenn Sie einen Fehler sehen, überprüfen Sie den Fehler und versuchen Sie erneut, Ihren benutzerdefinierten Autorisierer zu erstellen, und überprüfen Sie die Einträge erneut. Beachten Sie, dass jeder Benutzer einen eindeutigen Namen haben muss.
So erstellen Sie einen benutzerdefinierten Autorisierer (AWS CLI)
-
Ersetzen Sie Ihre Werte durch
authorizer-function-arn
undtoken-signing-public-keys
, und führen Sie dann den folgenden Befehl aus:aws iot create-authorizer \ --authorizer-name "my-new-authorizer" \ --token-key-name "tokenKeyName" \ --status ACTIVE \ --no-signing-disabled \ --authorizer-function-arn "
arn:aws:lambda:
" \ --token-signing-public-keys FirstKey="Region
:57EXAMPLE833:function:custom-auth-function-----BEGIN PUBLIC KEY----- MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAvEBzOk4vhN+3LgslvEWt sLCqNmt5Damas3bmiTRvq2gjRJ6KXGTGQChqArAJwL1a9dkS9+maaXC3vc6xzx9z QPu/vQOe5tyzz1MsKdmtFGxMqQ3qjEXAMPLEOmqyUKPP5mff58k6ePSfXAnzBH0q lg2HioefrpU5OSAnpuRAjYKofKjbc2Vrn6N2G7hV+IfTBvCElf0csalS/Rk4phD5 oa4Y0GHISRnevypg5C8n9Rrz91PWGqP6M/q5DNJJXjMyleG92hQgu1N696bn5Dw8 FhedszFa6b2x6xrItZFzewNQkPMLMFhNrQIIyvshtT/F1LVCS5+v8AQ8UGGDfZmv QeqAMAF7WgagDMXcfgKSVU8yid2sIm56qsCLMvD2Sq8Lgzpey9N5ON1o1Cvldwvc KrJJtgwW6hVqRGuShnownLpgG86M6neZ5sRMbVNZO8OzcobLngJ0Ibw9KkcUdklW gvZ6HEJqBY2XE70iEXAMPLETPHzhqvK6Ei1HGxpHsXx6BNft582J1VpgYjXha8oa /NN7l7Zbj/euAb41IVtmX8JrD9z613d1iM5L8HluJlUzn62Q+VeNV2tdA7MfPfMC 8btGYladFAnitThaz6+F0VSBJPu7pZQoLnqyEp5zLMtF+kFl2yOBmGAP0RBivRd9 JWBUCG0bqcLQPeQyjbXSOfUCAwEAAQ== -----END PUBLIC KEY-----
"Wobei gilt:
-
Der
authorizer-function-arn
Wert ist der Amazon-Ressourcenname (ARN) der Lambda-Funktion, die Sie für Ihren benutzerdefinierten Authorizer erstellt haben. -
Der Wert
token-signing-public-keys
umfasst den Namen des Schlüssels,FirstKey
, und den Inhalt der Dateipublic-key.pem
. Achten Sie darauf, die Zeilen aus der Datei mit-----BEGIN PUBLIC KEY-----
und-----END PUBLIC KEY-----
einzuschließen und dem Inhalt der Datei keine Zeilenvorschübe, Zeilenumbrüche oder andere Zeichen hinzuzufügen oder aus ihm zu entfernen.Hinweis: Seien Sie vorsichtig bei der Eingabe des öffentlichen Schlüssels, da jede Wertänderung des öffentlichen Schlüssels diesen unbrauchbar macht.
-
-
Wenn der benutzerdefinierte Autorisierer erstellt wurde, gibt der Befehl den Namen und den Namen ARN der neuen Ressource zurück, z. B. im Folgenden.
{ "authorizerName": "my-new-authorizer", "authorizerArn": "arn:aws:iot:
Region
:57EXAMPLE833:authorizer/my-new-authorizer" }Speichern Sie den Wert
authorizerArn
zur Verwendung im nächsten Schritt.Denken Sie daran, dass jeder Benutzer einen eindeutigen Namen haben muss.
Autorisieren der benutzerdefinierten Autorisierer-Ressource
In diesem Abschnitt erteilen Sie der benutzerdefinierten Autorisierer-Ressource, die Sie gerade erstellt haben, die Berechtigung zum Ausführen der Lambda-Funktion. Um die Berechtigung zu erteilen, können Sie den Befehl add-permission CLI verwenden.
Erteilen Sie Ihrer Lambda-Funktion die Erlaubnis mit dem AWS CLI
-
Geben Sie nach der Eingabe Ihrer Werte den folgenden Befehl ein. Beachten Sie, dass der Wert
statement-id
eindeutig sein muss. Ersetzen Sie
durch einen anderen Wert, wenn Sie dieses Tutorial schon einmal ausgeführt haben oder wenn Sie einen FehlerId-1234
ResourceConflictException
angezeigt bekommen.aws lambda add-permission \ --function-name "custom-auth-function" \ --principal "iot.amazonaws.com" \ --action "lambda:InvokeFunction" \ --statement-id "
Id-1234
" \ --source-arnauthorizerArn
-
Wenn der Befehl erfolgreich ist, gibt er eine Berechtigungsanweisung zurück, wie in diesem Beispiel. Sie können mit dem nächsten Abschnitt fortfahren, um den benutzerdefinierten Autorisierer zu testen.
{ "Statement": "{\"Sid\":\"
Id-1234
\",\"Effect\":\"Allow\",\"Principal\":{\"Service\":\"iot.amazonaws.com\"},\"Action\":\"lambda:InvokeFunction\",\"Resource\":\"arn:aws:lambda:Region
:57EXAMPLE833:function:custom-auth-function\",\"Condition\":{\"ArnLike\":{\"AWS:SourceArn\":\"arn:aws:lambda:Region
:57EXAMPLE833:function:custom-auth-function\"}}}" }Wenn der Befehl nicht erfolgreich ist, wird ein Fehler zurückgegeben, wie in diesem Beispiel. Sie müssen den Fehler überprüfen und korrigieren, bevor Sie fortfahren können.
An error occurred (AccessDeniedException) when calling the AddPermission operation: User: arn:aws:iam::57EXAMPLE833:user/EXAMPLE-1 is not authorized to perform: lambda:AddPer mission on resource: arn:aws:lambda:
Region
:57EXAMPLE833:function:custom-auth-function
Schritt 4: Testen Sie den Authorizer, indem Sie ihn anrufen test-invoke-authorizer
Wenn alle Ressourcen definiert sind, rufen Sie in diesem Abschnitt test-invoke-authorizer von der Befehlszeile aus auf, um den Autorisierungsdurchgang zu testen.
Beachten Sie, dass der Autorisierer nicht definiert ist, wenn er von der Befehlszeile aus aufgerufen protocolData
wird, sodass der Autorisierer immer ein Dokument zurückgibt. DENY Dieser Test bestätigt jedoch, dass Ihr benutzerdefinierter Autorisierer und Ihre Lambda-Funktion korrekt konfiguriert sind – auch wenn die Lambda-Funktion nicht vollständig getestet wird.
Um Ihren benutzerdefinierten Authorizer und seine Lambda-Funktion zu testen, verwenden Sie AWS CLI
-
Führen Sie in dem Verzeichnis, welches die
private-key.pem
-Datei, die Sie in einem vorherigen Schritt erstellt haben, enthält, den folgenden Befehl aus.echo -n "tokenKeyValue" | openssl dgst -sha256 -sign private-key.pem | openssl base64 -A
Mit diesem Befehl wird eine Signaturzeichenfolge zur Verwendung im nächsten Schritt generiert. Die Signaturzeichenfolge sollte wie folgt aussehen:
dBwykzlb+fo+JmSGdwoGr8dyC2qB/IyLefJJr+rbCvmu9Jl4KHAA9DG+V+MMWu09YSA86+64Y3Gt4tOykpZqn9mn VB1wyxp+0bDZh8hmqUAUH3fwi3fPjBvCa4cwNuLQNqBZzbCvsluv7i2IMjEg+CPY0zrWt1jr9BikgGPDxWkjaeeh bQHHTo357TegKs9pP30Uf4TrxypNmFswA5k7QIc01n4bIyRTm90OyZ94R4bdJsHNig1JePgnuOBvMGCEFE09jGjj szEHfgAUAQIWXiVGQj16BU1xKpTGSiTAwheLKUjITOEXAMPLECK3aHKYKY+d1vTvdthKtYHBq8MjhzJ0kggbt29V QJCb8RilN/P5+vcVniSXWPplyB5jkYs9UvG08REoy64AtizfUhvSul/r/F3VV8ITtQp3aXiUtcspACi6ca+tsDuX f3LzCwQQF/YSUy02u5XkWn+sto6KCkpNlkD0wU8gl3+kOzxrthnQ8gEajd5Iylx230iqcXo3osjPha7JDyWM5o+K EWckTe91I1mokDr5sJ4JXixvnJTVSx1li49IalW4en1DAkc1a0s2U2UNm236EXAMPLELotyh7h+flFeloZlAWQFH xRlXsPqiVKS1ZIUClaZWprh/orDJplpiWfBgBIOgokJIDGP9gwhXIIk7zWrGmWpMK9o=
Kopieren Sie diese Signaturzeichenfolge zur Verwendung im nächsten Schritt. Achten Sie darauf, keine zusätzlichen Zeichen einzufügen oder Zeichen wegzulassen.
-
Ersetzen Sie in diesem Befehl den Wert
token-signature
durch die Signaturzeichenfolge aus dem vorherigen Schritt und führen Sie diesen Befehl aus, um Ihren Autorisierer zu testen.aws iot test-invoke-authorizer \ --authorizer-name my-new-authorizer \ --token tokenKeyValue \ --token-signature
dBwykzlb+fo+JmSGdwoGr8dyC2qB/IyLefJJr+rbCvmu9Jl4KHAA9DG+V+MMWu09YSA86+64Y3Gt4tOykpZqn9mnVB1wyxp+0bDZh8hmqUAUH3fwi3fPjBvCa4cwNuLQNqBZzbCvsluv7i2IMjEg+CPY0zrWt1jr9BikgGPDxWkjaeehbQHHTo357TegKs9pP30Uf4TrxypNmFswA5k7QIc01n4bIyRTm90OyZ94R4bdJsHNig1JePgnuOBvMGCEFE09jGjjszEHfgAUAQIWXiVGQj16BU1xKpTGSiTAwheLKUjITOEXAMPLECK3aHKYKY+d1vTvdthKtYHBq8MjhzJ0kggbt29VQJCb8RilN/P5+vcVniSXWPplyB5jkYs9UvG08REoy64AtizfUhvSul/r/F3VV8ITtQp3aXiUtcspACi6ca+tsDuXf3LzCwQQF/YSUy02u5XkWn+sto6KCkpNlkD0wU8gl3+kOzxrthnQ8gEajd5Iylx230iqcXo3osjPha7JDyWM5o+KEWckTe91I1mokDr5sJ4JXixvnJTVSx1li49IalW4en1DAkc1a0s2U2UNm236EXAMPLELotyh7h+flFeloZlAWQFHxRlXsPqiVKS1ZIUClaZWprh/orDJplpiWfBgBIOgokJIDGP9gwhXIIk7zWrGmWpMK9o=
Wenn der Befehl erfolgreich ist, gibt er die Informationen zurück, die von Ihrer benutzerdefinierten Autorisierungsfunktion generiert wurden, wie in diesem Beispiel.
{ "isAuthenticated": true, "principalId": "principalId", "policyDocuments": [ "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Action\":\"iot:*\",\"Effect\":\"Deny\",\"Resource\":\"arn:aws:iot:
Region
:57EXAMPLE833:*\"}]}" ], "refreshAfterInSeconds": 600, "disconnectAfterInSeconds": 3600 }Wenn bei diesem Befehl ein Fehler zurückgegeben wird, überprüfen Sie den Fehler und überprüfen Sie erneut die Befehle, die Sie in diesem Abschnitt verwendet haben.
Schritt 5: Testen Sie das Veröffentlichen von MQTT Nachrichten mit Postman
-
Um Ihren Gerätedaten-Endpunkt über die Befehlszeile abzurufen, rufen Sie describe-endpoint
auf, wie hier dargestellt aws iot describe-endpoint --output text --endpoint-type iot:Data-ATS
Speichern Sie diese Adresse, um sie
device_data_endpoint_address
in einem späteren Schritt zu verwenden. -
Öffnen Sie ein neues Postman-Fenster und erstellen Sie eine neue HTTP POST Anfrage.
-
Öffnen Sie auf Ihrem Computer die Postman-App.
-
Wählen Sie in Postman im Menü Datei die Option Neu….
-
Wählen Sie im Dialogfeld Neu die Option Anfrage.
-
Unter Anfrage speichern:
-
Geben Sie unter Name der Anfrage
Custom authorizer test request
ein. -
Wählen Sie unter Sammlung oder Ordner zum Speichern auswählen: eine Sammlung aus bzw. erstellen Sie eine, in der diese Anfrage gespeichert werden soll.
-
Wählen Sie Speichern unter.
collection_name
-
-
-
Erstellen Sie die POST Anfrage, um Ihren benutzerdefinierten Authorizer zu testen.
-
Wählen Sie in der Auswahl der Anforderungsmethode neben dem URL Feld die Option. POST
-
Erstellen Sie in dem URL Feld das URL für Ihre Anfrage, indem Sie in einem vorherigen Schritt Folgendes URL zusammen mit dem
device_data_endpoint_address
Befehl from the describe-endpointverwenden. https://
device_data_endpoint_address
:443/topics/test/cust-auth/topic?qos=0&actionToken=allowBeachten Sie, dass dies den
actionToken=allow
Abfrageparameter URL beinhaltet, der Ihre Lambda-Funktion anweist, ein Richtliniendokument zurückzugeben, das den Zugriff AWS IoT auf ermöglicht. Nachdem Sie den eingegeben habenURL, werden die Abfrageparameter auch auf der Registerkarte Params von Postman angezeigt. -
Wählen Sie auf der Registerkarte Auth im Feld Typ die Option Keine Auth.
-
Auf der Registerkarte Header:
-
Wenn ein Host-Schlüssel aktiviert ist, deaktivieren Sie diesen.
-
Fügen Sie diese neuen Header am Ende der Header-Liste hinzu, und bestätigen Sie, dass sie aktiviert sind. Ersetzen Sie den
Host
Wert durch Ihrendevice_data_endpoint_address
und denx-amz-customauthorizer-signature
Wert durch die Signaturzeichenfolge, die Sie mit dem test-invoke-authorize Befehl im vorherigen Abschnitt verwendet haben.Schlüssel Wert x-amz-customauthorizer-name
my-new-authorizer
Host
device_data_endpoint_address
tokenKeyName
tokenKeyValue
x-amz-customauthorizer-signature
dBwykzlb+fo+JmSGdwoGr8dyC2qB/IyLefJJr+rbCvmu9Jl4KHAA9DG+V+MMWu09YSA86+64Y3Gt4tOykpZqn9mnVB1wyxp+0bDZh8hmqUAUH3fwi3fPjBvCa4cwNuLQNqBZzbCvsluv7i2IMjEg+CPY0zrWt1jr9BikgGPDxWkjaeehbQHHTo357TegKs9pP30Uf4TrxypNmFswA5k7QIc01n4bIyRTm90OyZ94R4bdJsHNig1JePgnuOBvMGCEFE09jGjjszEHfgAUAQIWXiVGQj16BU1xKpTGSiTAwheLKUjITOEXAMPLECK3aHKYKY+d1vTvdthKtYHBq8MjhzJ0kggbt29VQJCb8RilN/P5+vcVniSXWPplyB5jkYs9UvG08REoy64AtizfUhvSul/r/F3VV8ITtQp3aXiUtcspACi6ca+tsDuXf3LzCwQQF/YSUy02u5XkWn+sto6KCkpNlkD0wU8gl3+kOzxrthnQ8gEajd5Iylx230iqcXo3osjPha7JDyWM5o+KEWckTe91I1mokDr5sJ4JXixvnJTVSx1li49IalW4en1DAkc1a0s2U2UNm236EXAMPLELotyh7h+flFeloZlAWQFHxRlXsPqiVKS1ZIUClaZWprh/orDJplpiWfBgBIOgokJIDGP9gwhXIIk7zWrGmWpMK9o=
-
-
Auf der Registerkarte „Text“:
-
Wählen Sie im Optionsfeld für das Datenformat die Option Raw.
-
Wählen Sie in der Datentypliste JavaScript.
-
Geben Sie in das Textfeld die JSON folgende Nachrichten-Payload für Ihre Testnachricht ein:
{ "data_mode": "test", "vibration": 200, "temperature": 40 }
-
-
-
Wählen Sie Senden aus, um die Anfrage zu senden.
Wenn die Anfrage erfolgreich war, wird Folgendes zurückgegeben:
{ "message": "OK", "traceId": "ff35c33f-409a-ea90-b06f-fbEXAMPLE25c" }
Die erfolgreiche Antwort weist darauf hin, dass Ihr benutzerdefinierter Autorisierer die Verbindung zu zugelassen hat AWS IoT und dass die Testnachricht an den Broker in zugestellt wurde. AWS IoT Core
Wenn ein Fehler zurückgegeben wird, überprüfen Sie die Fehlermeldung
device_data_endpoint_address
, die Signaturzeichenfolge und die anderen Header-Werte.
Bewahren Sie diese Anfrage in Postman auf, um Sie im nächsten Abschnitt zu verwenden.
Schritt 6: Nachrichten im MQTT Testclient anzeigen
Im vorherigen Schritt haben Sie mithilfe AWS IoT von Postman simulierte Gerätenachrichten an gesendet. Die erfolgreiche Antwort wies darauf hin, dass Ihr benutzerdefinierter Autorisierer die Verbindung zum AWS IoT gestattet hat und dass die Testnachricht an den Broker in AWS IoT Core zugestellt wurde. In diesem Abschnitt verwenden Sie den MQTT Testclient in der AWS IoT Konsole, um den Nachrichteninhalt dieser Nachricht so zu sehen, wie es bei anderen Geräten und Diensten der Fall ist.
So zeigen Sie die von Ihrem benutzerdefinierten Autorisierer autorisierten Testnachrichten an
-
Öffnen Sie in der AWS IoT Konsole den MQTTTestclient
. -
Geben Sie auf der Registerkarte Thema abonnieren im Themenfilter
test/cust-auth/topic
ein – das Nachrichtenthema aus dem vorherigen Abschnitt, das im Postman-Beispiel verwendet wurde. -
Wählen Sie Abonnieren.
Lassen Sie dieses Fenster für den nächsten Schritt geöffnet.
-
Wählen Sie in Postman in der Anfrage, die Sie für den vorherigen Abschnitt erstellt haben, die Option Senden.
Überprüfen Sie die Antwort, um sicherzustellen, dass sie erfolgreich war. Falls nicht, beheben Sie den Fehler, wie im vorherigen Abschnitt beschrieben.
-
Im MQTTTestclient sollten Sie einen neuen Eintrag sehen, der das Nachrichtenthema und, falls erweitert, die Nachrichten-Payload aus der Anfrage enthält, die Sie von Postman gesendet haben.
Wenn Sie Ihre Nachrichten im MQTTTestclient nicht sehen, sollten Sie Folgendes überprüfen:
-
Stellen Sie sicher, dass Ihre Postman-Anfrage erfolgreich zurückgegeben wurde. Wenn die Verbindung AWS IoT abgelehnt wird und ein Fehler zurückgegeben wird, wird die Nachricht in der Anfrage nicht an den Message Broker weitergeleitet.
-
Stellen Sie sicher, dass die zum Öffnen der AWS IoT Konsole AWS-Region verwendeten AWS-Konto und dieselben sind, die Sie im URL Postman verwenden.
-
Stellen Sie sicher, dass Sie den entsprechenden Endpunkt für den benutzerdefinierten Authorizer verwenden. Der Standard-IoT-Endpunkt unterstützt möglicherweise nicht die Verwendung benutzerdefinierter Autorisierer mit Lambda-Funktionen. Stattdessen können Sie Domänenkonfigurationen verwenden, um einen neuen Endpunkt zu definieren und diesen Endpunkt dann für den benutzerdefinierten Autorisierer anzugeben.
-
Stellen Sie sicher, dass Sie das Thema im MQTTTestclient korrekt eingegeben haben. Beim Themenfilter wird die Groß-/Kleinschreibung berücksichtigt. Im Zweifelsfall können Sie auch das
#
Thema abonnieren, das alle MQTT Nachrichten abonniert, die den Message Broker passieren AWS-Konto und zum Öffnen der AWS IoT Konsole AWS-Region verwendet werden.
-
Schritt 7: Überprüfen der Ergebnisse und die nächsten Schritte
In diesem Tutorial:
-
Haben Sie eine Lambda-Funktion als benutzerdefinierten Autorisierer-Handler erstellt.
-
Haben Sie einen benutzerdefinierten Autorisierer mit aktivierter Token-Signatur erstellt.
-
Haben Sie Ihren benutzerdefinierten Autorisierer mit dem Befehl test-invoke-authorizer getestet.
-
Sie haben ein MQTT Thema mit Postman
veröffentlicht und die Anfrage mit Ihrem benutzerdefinierten Autorisierer validiert -
Sie haben den MQTTTestclient verwendet, um die von Ihrem Postman-Test gesendeten Nachrichten anzusehen
Nächste Schritte
Nachdem Sie einige Nachrichten von Postman gesendet haben, um zu überprüfen, ob der benutzerdefinierte Autorisierer funktioniert, versuchen Sie zu experimentieren, um festzustellen, wie sich Änderungen an verschiedenen Aspekten dieses Tutorials auf die Ergebnisse auswirken. Hier sind einige Beispiele, die Ihnen den Einstieg erleichtern sollen.
-
Ändern Sie die Signaturzeichenfolge so, dass sie nicht mehr gültig ist, um zu sehen, wie unbefugte Verbindungsversuche behandelt werden. Sie sollten eine Fehlerantwort wie diese erhalten, und die Nachricht sollte nicht im MQTTTestclient erscheinen.
{ "message": "Forbidden", "traceId": "15969756-a4a4-917c-b47a-5433e25b1356" }
-
Weitere Informationen zum Auffinden von Fehlern, die bei der Entwicklung und Verwendung von AWS IoT Regeln auftreten können, finden Sie unterÜberwachung AWS IoT.
Schritt 8: Bereinigen
Wenn Sie dieses Tutorial wiederholen möchten, müssen Sie möglicherweise einige Ihrer benutzerdefinierten Autorisierer entfernen. Sie AWS-Konto können nur eine begrenzte Anzahl von benutzerdefinierten Autorisierern gleichzeitig konfigurieren. Sie erhalten einen, LimitExceededException
wenn Sie versuchen, einen neuen hinzuzufügen, ohne einen vorhandenen benutzerdefinierten Autorisierer zu entfernen.
So entfernen Sie einen benutzerdefinierten Autorisierer (Konsole)
-
Öffnen Sie die Seite Benutzerdefinierter Autorisierer der AWS IoT Konsole
und suchen Sie in der Liste der benutzerdefinierten Autorisierer nach dem benutzerdefinierten Autorisierer, den Sie entfernen möchten. -
Öffnen Sie die Seite mit den Details des benutzerdefinierten Autorisierers, und wählen Sie aus dem Menü Aktionen die Option Bearbeiten.
-
Heben Sie die Auswahl von Autorisierer aktivieren auf, und wählen Sie dann Aktualisieren.
Während ein benutzerdefinierter Autorisierer aktiv ist, können Sie ihn nicht löschen.
-
Öffnen Sie auf der Seite mit den Details des benutzerdefinierten Autorisierers das Menü Aktionen, und wählen Sie Löschen.
So entfernen Sie einen benutzerdefinierten Autorisierer (AWS CLI)
-
Listen Sie die benutzerdefinierten Autorisierer auf, die Sie installiert haben, und suchen Sie nach dem Namen des benutzerdefinierten Autorisierers, den Sie löschen möchten.
aws iot list-authorizers
-
Legen Sie den benutzerdefinierten Autorisierer auf
inactive
fest, indem Sie diesen Befehl ausführen, nachdem Sie
durchCustom_Auth_Name
authorizerName
des benutzerdefinierten Autorisierers, der gelöscht werden soll, ersetzt haben.aws iot update-authorizer --status INACTIVE --authorizer-name
Custom_Auth_Name
-
Löschen Sie den benutzerdefinierten Autorisierer, indem Sie diesen Befehl ausführen, nachdem Sie
durchCustom_Auth_Name
authorizerName
des benutzerdefinierten Autorisierers, der gelöscht werden soll, ersetzt haben.aws iot delete-authorizer --authorizer-name
Custom_Auth_Name