AWS S3和IAM - 定义策略,用户只能访问(读取)特定文件夹
创始人
2024-11-17 22:00:10
0

要实现让用户只能访问(读取)特定文件夹,可以使用AWS Identity and Access Management(IAM)和S3策略来控制访问权限。下面是一种解决方法,包含一个示例策略和代码示例:

首先,创建一个IAM策略,限制用户只能访问特定文件夹。假设该文件夹位于“my-bucket”存储桶中的“my-folder”路径下。以下是一个示例策略:

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Sid": "AllowListBucket",
      "Effect": "Allow",
      "Action": "s3:ListBucket",
      "Resource": "arn:aws:s3:::my-bucket"
    },
    {
      "Sid": "AllowReadFolder",
      "Effect": "Allow",
      "Action": [
        "s3:GetObject",
        "s3:GetObjectVersion"
      ],
      "Resource": "arn:aws:s3:::my-bucket/my-folder/*"
    }
  ]
}

上述策略分为两个声明(Statement):

  • 第一个声明允许用户列出存储桶的内容。
  • 第二个声明允许用户获取特定文件夹下的对象(文件)。

接下来,将该策略附加到IAM用户上。可以使用AWS Management Console、AWS CLI或AWS SDK进行操作。

以下是使用AWS SDK for Python(Boto3)的代码示例:

import boto3

# 创建IAM客户端
iam = boto3.client('iam')

# 定义IAM策略
policy_name = 'S3FolderReadAccess'
policy_document = '''
{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Sid": "AllowListBucket",
      "Effect": "Allow",
      "Action": "s3:ListBucket",
      "Resource": "arn:aws:s3:::my-bucket"
    },
    {
      "Sid": "AllowReadFolder",
      "Effect": "Allow",
      "Action": [
        "s3:GetObject",
        "s3:GetObjectVersion"
      ],
      "Resource": "arn:aws:s3:::my-bucket/my-folder/*"
    }
  ]
}
'''

# 创建IAM策略
response = iam.create_policy(
    PolicyName=policy_name,
    PolicyDocument=policy_document
)

# 获取策略ARN
policy_arn = response['Policy']['Arn']

# 创建IAM用户
user_name = 'my-user'
response = iam.create_user(UserName=user_name)

# 附加策略到IAM用户
response = iam.attach_user_policy(
    UserName=user_name,
    PolicyArn=policy_arn
)

print(f"用户 {user_name} 已被授予访问特定文件夹的权限。")

上述代码示例使用Boto3创建了一个IAM客户端,并通过create_policy方法创建了一个新的IAM策略。随后,使用create_user方法创建了一个新的IAM用户,并使用attach_user_policy方法将策略附加到该用户上。最后,打印出用户被授予访问特定文件夹权限的消息。

请确保将示例代码中的“my-bucket”和“my-folder”替换为实际的存储桶名称和文件夹路径。

相关内容

热门资讯

据统计!pokemomo辅助软... 据统计!pokemomo辅助软件,八张透视辅助,演示教程(有挂细节)1、全新机制【八张透视辅助ai辅...
明白辅助挂!红龙poker作弊... 明白辅助挂!红龙poker作弊指令,奇迹脚本辅助,大纲教程(有挂方针)1、游戏颠覆性的策略玩法,独创...
目前!德州圈脚本,德普之星辅助... 目前!德州圈脚本,德普之星辅助器,积累教程(真的有挂)1、操作简单,无需德普之星辅助器手机版透视脚本...
相较于以往!智星菠萝有挂吗,来... 相较于以往!智星菠萝有挂吗,来来拼十辅助免费辅助,方针教程(存在有挂)1、首先打开来来拼十辅助免费辅...
据通报!德扑之心免费透视,广东... 据通报!德扑之心免费透视,广东雀神挂机怎么样,步骤教程(有挂方略)1、该软件可以轻松地帮助玩家将广东...
有玩家发现!aapoker真的... 有玩家发现!aapoker真的假的,闲聚辅助器,绝活儿教程(讲解有挂)1)闲聚辅助器免费钻石:进一步...
方法辅助挂!德州局脚本,博雅红... 方法辅助挂!德州局脚本,博雅红河西元红河挂,方式教程(有挂讲解)1、博雅红河西元红河挂免费辅助多个强...
有玩家发现!扑克之星辅助,jj... 有玩家发现!扑克之星辅助,jj斗地主外卦,讲义教程(有挂分析)1、进入到jj斗地主外卦是否有挂之后,...
黑科技辅助挂!hhpoker辅... 黑科技辅助挂!hhpoker辅助,陕麻圈辅助开挂软件,妙招教程(有挂详情);1、下载好陕麻圈辅助开挂...
为切实保障!epoker透视底... 为切实保障!epoker透视底牌,哈局八张辅助,总结教程(有挂方略)1、该软件可以轻松地帮助玩家将哈...