| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 | from aliyunsdkcore import clientfrom aliyunsdksts.request.v20150401 import AssumeRoleRequestimport jsonimport oss2# Endpoint以杭州为例,其它egion请按实际情况填写。endpoint = 'oss-cn-shenzhen.aliyuncs.com'access_key_id = 'LTAIyMkGfEdogyL9'access_key_secret = '71uIjpsqVOmF7DAITRyRuc259jHOjO'bucket_name = 'cloudvod1'# role_arn是角色的资源名称。role_arn = 'acs:ram::1901342792446414:role/stsoss'clt = client.AcsClient(access_key_id, access_key_secret, 'cn-shenzhen')req = AssumeRoleRequest.AssumeRoleRequest()# 设置返回值格式为JSON。req.set_accept_format('json')req.set_RoleArn(role_arn)req.set_RoleSessionName('uid13241234123')req.set_DurationSeconds(3600)policys = {    "Version": "1",    "Statement": [        {            "Action": [                "oss:PutObject",                "oss:DeleteObject",            ],            # "Resource": ["acs:oss:*:*:cloudvod1/*"],            "Resource": ["acs:oss:*:*:cloudvod1/test/*"],            "Effect": "Allow",            "Condition": {                "IpAddress": {                    "acs:SourceIp": "120.237.157.184"                }            }        }    ]}req.set_Policy(Policy=json.dumps(policys))body = clt.do_action(req)# body = clt.do_action_with_exception(req)# 使用RAM账号的AccessKeyId和AccessKeySecret向STS申请临时token。token = json.loads(body)print(token)exit()# 使用临时token中的认证信息初始化StsAuth实例。auth = oss2.StsAuth(token['Credentials']['AccessKeyId'],                    token['Credentials']['AccessKeySecret'],                    token['Credentials']['SecurityToken'])print(auth)# 使用StsAuth实例初始化存储空间。bucket = oss2.Bucket(auth, endpoint, bucket_name)# 上传一个字符串。# res = bucket.put_object('oss_media_hls.ts', b'hello world')res = bucket.put_object('test/test-name.txt', b'hello world')print(res)
 |