小编ouy*_*eyu的帖子

如何在具有 IAM 角色的 ec2 实例上使用 java 访问 dynamodb 而无需访问凭据

我想使用 Java 访问 Ec2 实例上的 Dynamodb。此 Ec2 实例已被授予 IAM 角色,我可以通过该角色使用 aws CLI:aws dynamodb list-table 直接访问 Dynamodb。现在我尝试通过 Java 访问 Dynamodb。Java 代码应该能够承担角色,但它不起作用。

public static void main(String[] args) throws Exception {

    String ROLE_ARN = "arn:aws:iam::....";

    AWSSecurityTokenServiceClient stsClient = new AWSSecurityTokenServiceClient();

    AssumeRoleRequest assumeRequest = new AssumeRoleRequest()
        .withRoleArn(ROLE_ARN)
        .withDurationSeconds(3600)
        .withRoleSessionName("demo");

    AssumeRoleResult assumeResult = stsClient.assumeRole(assumeRequest);

    BasicSessionCredentials temporaryCredentials = new BasicSessionCredentials(
                assumeResult.getCredentials().getAccessKeyId(),
                assumeResult.getCredentials().getSecretAccessKey(),
                assumeResult.getCredentials().getSessionToken());

    AmazonDynamoDBClient client = new AmazonDynamoDBClient(temporaryCredentials)

    DynamoDB dynamoDB = new DynamoDB(client);

    TableCollection<ListTablesResult> tables = dynamoDB.listTables();
    Iterator<Table> iterator_t = tables.iterator();
    System.out.println("Listing table names");
    while (iterator_t.hasNext()) …
Run Code Online (Sandbox Code Playgroud)

java role amazon-dynamodb amazon-iam

5
推荐指数
1
解决办法
3723
查看次数

标签 统计

amazon-dynamodb ×1

amazon-iam ×1

java ×1

role ×1