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.
Verwalten von IAM Zugriffsschlüsseln
Erstellen eines Zugriffsschlüssels
Um einen IAM Zugriffsschlüssel zu erstellen, rufen Sie die -IamClient’s
createAccessKey
Methode mit einem -CreateAccessKeyRequest
Anmerkung
Sie müssen die Region auf AWS_GLOBAL setzen, damit IamClient
Aufrufe funktionieren, da ein globaler Service IAM ist.
Importe
import software.amazon.awssdk.services.iam.model.CreateAccessKeyRequest; import software.amazon.awssdk.services.iam.model.CreateAccessKeyResponse; import software.amazon.awssdk.regions.Region; import software.amazon.awssdk.services.iam.IamClient; import software.amazon.awssdk.services.iam.model.IamException;
Code
public static String createIAMAccessKey(IamClient iam,String user) { try { CreateAccessKeyRequest request = CreateAccessKeyRequest.builder() .userName(user).build(); CreateAccessKeyResponse response = iam.createAccessKey(request); String keyId = response.accessKey().accessKeyId(); return keyId; } catch (IamException e) { System.err.println(e.awsErrorDetails().errorMessage()); System.exit(1); } return ""; }
Sehen Sie sich das vollständige Beispiel
Auflisten von Zugriffsschlüsseln
Um die Zugriffsschlüssel für einen bestimmten Benutzer aufzulisten, erstellen Sie ein ListAccessKeysRequest
IamClient’s
listAccessKeys
Methode .
Anmerkung
Wenn Sie keinen Benutzernamen für angebenlistAccessKeys
, wird versucht, die Zugriffsschlüssel aufzulisten, die dem zugeordnet sind AWS-Konto , der die Anforderung signiert hat.
Importe
import software.amazon.awssdk.services.iam.model.AccessKeyMetadata; import software.amazon.awssdk.services.iam.model.IamException; import software.amazon.awssdk.services.iam.model.ListAccessKeysRequest; import software.amazon.awssdk.services.iam.model.ListAccessKeysResponse; import software.amazon.awssdk.regions.Region; import software.amazon.awssdk.services.iam.IamClient;
Code
public static void listKeys( IamClient iam,String userName ){ try { boolean done = false; String newMarker = null; while (!done) { ListAccessKeysResponse response; if(newMarker == null) { ListAccessKeysRequest request = ListAccessKeysRequest.builder() .userName(userName).build(); response = iam.listAccessKeys(request); } else { ListAccessKeysRequest request = ListAccessKeysRequest.builder() .userName(userName) .marker(newMarker).build(); response = iam.listAccessKeys(request); } for (AccessKeyMetadata metadata : response.accessKeyMetadata()) { System.out.format("Retrieved access key %s", metadata.accessKeyId()); } if (!response.isTruncated()) { done = true; } else { newMarker = response.marker(); } } } catch (IamException e) { System.err.println(e.awsErrorDetails().errorMessage()); System.exit(1); } }
Die Ergebnisse von listAccessKeys
sind seitenweise angeordnet (mit einem Standardhöchstwert von 100 Datensätzen pro Aufruf). Sie können isTruncated
für das zurückgegebene ListAccessKeysResponse
marker
für ListAccessKeysResponse
auf und verwenden es beim Erstellen einer neuen Anforderung. Verwenden Sie diese neue Anforderung im nächsten Aufruf von listAccessKeys
.
Sehen Sie sich das vollständige Beispiel
Abrufen der letzten Nutzungszeit eines Zugriffsschlüssels
Um die Zeit zu erhalten, zu der ein Zugriffsschlüssel zuletzt verwendet wurde, rufen Sie die IamClient’s
getAccessKeyLastUsed
Methode mit der ID des Zugriffsschlüssels auf (die mit einem -GetAccessKeyLastUsedRequest
Anschließend können Sie das zurückgegebene GetAccessKeyLastUsedResponse
Importe
import software.amazon.awssdk.regions.Region; import software.amazon.awssdk.services.iam.IamClient; import software.amazon.awssdk.services.iam.model.GetAccessKeyLastUsedRequest; import software.amazon.awssdk.services.iam.model.GetAccessKeyLastUsedResponse; import software.amazon.awssdk.services.iam.model.IamException;
Code
public static void getAccessKeyLastUsed(IamClient iam, String accessId ){ try { GetAccessKeyLastUsedRequest request = GetAccessKeyLastUsedRequest.builder() .accessKeyId(accessId).build(); GetAccessKeyLastUsedResponse response = iam.getAccessKeyLastUsed(request); System.out.println("Access key was last used at: " + response.accessKeyLastUsed().lastUsedDate()); } catch (IamException e) { System.err.println(e.awsErrorDetails().errorMessage()); System.exit(1); } System.out.println("Done"); }
Sehen Sie sich das vollständige Beispiel
Aktivieren oder Deaktivieren von Zugriffsschlüsseln
Sie können einen Zugriffsschlüssel aktivieren oder deaktivieren, indem Sie ein UpdateAccessKeyRequest
status
IamClient’s
updateAccessKey
Methode übergeben.
Importe
import software.amazon.awssdk.services.iam.model.IamException; import software.amazon.awssdk.services.iam.model.StatusType; import software.amazon.awssdk.services.iam.model.UpdateAccessKeyRequest; import software.amazon.awssdk.regions.Region; import software.amazon.awssdk.services.iam.IamClient;
Code
public static void updateKey(IamClient iam, String username, String accessId, String status ) { try { if (status.toLowerCase().equalsIgnoreCase("active")) { statusType = StatusType.ACTIVE; } else if (status.toLowerCase().equalsIgnoreCase("inactive")) { statusType = StatusType.INACTIVE; } else { statusType = StatusType.UNKNOWN_TO_SDK_VERSION; } UpdateAccessKeyRequest request = UpdateAccessKeyRequest.builder() .accessKeyId(accessId) .userName(username) .status(statusType) .build(); iam.updateAccessKey(request); System.out.printf( "Successfully updated the status of access key %s to" + "status %s for user %s", accessId, status, username); } catch (IamException e) { System.err.println(e.awsErrorDetails().errorMessage()); System.exit(1); } }
Sehen Sie sich das vollständige Beispiel
Löschen eines Zugriffsschlüssels
Um einen Zugriffsschlüssel dauerhaft zu löschen, rufen Sie die -IamClient’s
deleteKey
Methode auf und stellen Sie ihr eine mit der ID und dem Benutzernamen des Zugriffsschlüssels DeleteAccessKeyRequest
Anmerkung
Nach dem Löschen können Schlüssel nicht mehr abgerufen oder verwendet werden. Um einen Schlüssel vorübergehend zu deaktivieren, damit er später wieder aktiviert werden kann, verwenden Sie stattdessen die -updateAccessKeyMethode.
Importe
import software.amazon.awssdk.regions.Region; import software.amazon.awssdk.services.iam.IamClient; import software.amazon.awssdk.services.iam.model.DeleteAccessKeyRequest; import software.amazon.awssdk.services.iam.model.IamException;
Code
public static void deleteKey(IamClient iam ,String username, String accessKey ) { try { DeleteAccessKeyRequest request = DeleteAccessKeyRequest.builder() .accessKeyId(accessKey) .userName(username) .build(); iam.deleteAccessKey(request); System.out.println("Successfully deleted access key " + accessKey + " from user " + username); } catch (IamException e) { System.err.println(e.awsErrorDetails().errorMessage()); System.exit(1); } }
Sehen Sie sich das vollständige Beispiel
Weitere Informationen
-
CreateAccessKey in der IAM API-Referenz zu
-
ListAccessKeys in der IAM API-Referenz zu
-
GetAccessKeyLastUsed in der IAM API-Referenz zu
-
UpdateAccessKey in der IAM API-Referenz zu
-
DeleteAccessKey in der IAM API-Referenz zu