Weitere AWS SDK Beispiele sind im Repo AWS Doc SDK Examples
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.
Verwenden Sie es GenerateRandom
mit einem AWS SDK oder CLI
Die folgenden Codebeispiele zeigen die VerwendungGenerateRandom
.
- CLI
-
- AWS CLI
-
Beispiel 1: Um eine 256-Bit-Zufallsbytezeichenfolge zu generieren (Linux oder) macOs
Das folgende
generate-random
Beispiel generiert eine Base64-kodierte 256-Bit-Zufallsbytezeichenfolge (32 Byte). Das Beispiel dekodiert die Bytezeichenfolge und speichert sie in der Zufallsdatei.Wenn Sie diesen Befehl ausführen, müssen Sie den
number-of-bytes
Parameter verwenden, um die Länge des Zufallswerts in Byte anzugeben.Sie geben keinen KMS Schlüssel an, wenn Sie diesen Befehl ausführen. Die zufällige Byte-Zeichenfolge hat nichts mit einem KMS Schlüssel zu tun.
AWS KMSGeneriert standardmäßig die Zufallszahl. Wenn Sie jedoch einen benutzerdefinierten Schlüsselspeicher angeben < https://docs.aws.amazon.com/kms/ latest/developerguide/custom - key-store-overview .html>, wird die zufällige Byte-Zeichenfolge in dem AWS HSM Cloud-Cluster generiert, der dem benutzerdefinierten Schlüsselspeicher zugeordnet ist.
In diesem Beispiel werden die folgenden Parameter und Werte verwendet:
Es verwendet den erforderlichen
--number-of-bytes
Parameter mit dem Wert von,32
um eine 32-Byte-Zeichenfolge (256-Bit) anzufordern.Es verwendet den--output
Parameter mit dem Wert von,text
AWS CLI um die Ausgabe als Text zurückzugeben, anstatt vonJSON. Es verwendet den,--query parameter
um den Wert derPlaintext
Eigenschaft aus der Antwort zu extrahieren.Es leitet (|) die Ausgabe des Befehls an dasbase64
Hilfsprogramm weiter, das die extrahierte Ausgabe dekodiert. Es verwendet den Umleitungsoperator (>), um die dekodierte Bytezeichenfolge in derExampleRandom
Datei zu speichern.IT verwendet die Umleitungsoperator (>), um den binären Chiffretext in einer Datei zu speichern.aws kms generate-random \ --number-of-bytes 32 \ --output text \ --query Plaintext | base64 --decode > ExampleRandom
Mit diesem Befehl wird keine Ausgabe zurückgegeben.
Weitere Informationen finden Sie GenerateRandomin der AWS Key Management Service Reference. API
Beispiel 2: Generieren einer 256-Bit-Zufallszahl (Windows-Befehlszeile)
Im folgenden Beispiel wird der
generate-random
Befehl verwendet, um eine Base64-kodierte 256-Bit- (32-Byte) -Bit-Zufallsbytezeichenfolge zu generieren. Das Beispiel dekodiert die Bytezeichenfolge und speichert sie in der Zufallsdatei. Dieses Beispiel entspricht dem vorherigen Beispiel, außer dass es dascertutil
Hilfsprogramm in Windows verwendet, um die zufällige Bytezeichenfolge base64-dekodieren zu lassen, bevor sie in einer Datei gespeichert wird.Generieren Sie zunächst eine Base64-kodierte Zufallsbytezeichenfolge und speichern Sie sie in einer temporären Datei,.
ExampleRandom.base64
aws kms generate-random \ --number-of-bytes
32
\ --outputtext
\ --queryPlaintext
>
ExampleRandom.base64
Da die Ausgabe des
generate-random
Befehls in einer Datei gespeichert wird, erzeugt dieses Beispiel keine Ausgabe.Verwenden Sie nun den
certutil -decode
Befehl, um die Base64-kodierte Bytezeichenfolge in der Datei zu dekodieren.ExampleRandom.base64
Anschließend wird die dekodierte Bytezeichenfolge in der Datei gespeichert.ExampleRandom
certutil -decode ExampleRandom.base64 ExampleRandom
Ausgabe:
Input Length = 18 Output Length = 12 CertUtil: -decode command completed successfully.
Weitere Informationen finden Sie GenerateRandomin der APIReferenz zum AWS Key Management Service.
-
APIEinzelheiten finden Sie GenerateRandom
unter AWS CLI Befehlsreferenz.
-
- Rust
-
- SDKfür Rust
-
Anmerkung
Es gibt noch mehr dazu GitHub. Sie sehen das vollständige Beispiel und erfahren, wie Sie das AWS -Code-Beispiel-Repository
einrichten und ausführen. async fn make_string(client: &Client, length: i32) -> Result<(), Error> { let resp = client .generate_random() .number_of_bytes(length) .send() .await?; // Did we get an encrypted blob? let blob = resp.plaintext.expect("Could not get encrypted text"); let bytes = blob.as_ref(); let s = base64::encode(bytes); println!(); println!("Data key:"); println!("{}", s); Ok(()) }
-
APIEinzelheiten finden Sie GenerateRandom
in der AWS SDKAPIRust-Referenz.
-