AWS S3预签名URL与自定义策略
创始人
2024-11-17 23:00:57
0

AWS S3预签名URL与自定义策略结合使用可以实现更精细的访问控制。下面是一个使用Python语言编写的示例代码,演示了如何生成具有自定义策略的S3预签名URL:

import boto3
from botocore.exceptions import ClientError
import datetime

def generate_presigned_url(bucket_name, object_name, expiration=3600, custom_policy=None):
    """Generate a presigned URL to share an S3 object

    :param bucket_name: string
    :param object_name: string
    :param expiration: Time in seconds for the presigned URL to remain valid
    :param custom_policy: Custom policy string as JSON format
    :return: Presigned URL as string. If error, returns None.
    """

    # Generate a presigned URL for the S3 object
    s3_client = boto3.client('s3')
    try:
        params = {
            'Bucket': bucket_name,
            'Key': object_name
        }
        if custom_policy:
            params['Policy'] = custom_policy
        
        url = s3_client.generate_presigned_url(
            'get_object',
            Params=params,
            ExpiresIn=expiration
        )

        return url
    except ClientError as e:
        print(e)
        return None

# 示例用法
bucket = 'your-bucket-name'
object_key = 'your-object-key'

# 创建自定义策略
policy = {
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "AllowGetObject",
            "Effect": "Allow",
            "Principal": "*",
            "Action": "s3:GetObject",
            "Resource": f"arn:aws:s3:::{bucket}/{object_key}",
            "Condition": {
                "IpAddress": {
                    "aws:SourceIp": "192.168.0.1/24"
                }
            }
        }
    ]
}

# 将策略转换为JSON字符串
import json
policy_json = json.dumps(policy)

# 生成预签名URL
url = generate_presigned_url(bucket, object_key, expiration=3600, custom_policy=policy_json)
print(url)

上述代码中的generate_presigned_url函数用于生成带有自定义策略的S3预签名URL。你可以根据自己的需求修改策略中的条件和资源等信息。

注意,预签名URL的有效期可以自行设置,默认为3600秒。此外,代码中使用的策略为示例策略,你需要根据自己的需求自行编写适用的策略。

希望对你有所帮助!

相关内容

热门资讯

透视有挂!aapoker怎么控... 透视有挂!aapoker怎么控制牌,aapoker ai插件-确实真的有辅助方法(哔哩哔哩)1、操作...
透视分享!wpk德州局透视,微... 透视分享!wpk德州局透视,微扑克微乐辅助-真是真的是有辅助技巧(哔哩哔哩)德州局透视能透视中分为三...
透视详细!wepoker私人局... 透视详细!wepoker私人局外卦,we poker辅助器-好像是真的有辅助攻略(哔哩哔哩)1、超多...
透视关于!wepoker有没有... 透视关于!wepoker有没有挂,wepoker一直输的号能继续打吗-本来真的是有辅助工具(哔哩哔哩...
透视了解!wepoker底牌透... 透视了解!wepoker底牌透视,We poker辅助器下载-一贯一直都是有辅助攻略(哔哩哔哩)ep...
透视关于!wpk模拟器多开,w... 透视关于!wpk模拟器多开,wpk透视辅助下载-确实一直都是有辅助软件(哔哩哔哩)辅助器是一种具有地...
透视详细!如何判断wpk辅助软... 透视详细!如何判断wpk辅助软件的真假,wpk真的有透视嘛-都是一直总是有辅助脚本(哔哩哔哩);1、...
透视开挂!wpk可以作弊吗,w... 透视开挂!wpk可以作弊吗,wpk私人局有透视吗-竟然是真的有辅助app(哔哩哔哩)1、破解器简单,...
透视详细!wepoker私人局... 透视详细!wepoker私人局规律,wepoker辅助器最新版本更新内容-切实真的是有辅助技巧(哔哩...
透视开挂!wpk透视辅助方法,... 透视开挂!wpk透视辅助方法,wpk安卓下载辅助-都是存在有辅助app(哔哩哔哩)1、超多福利:超高...