solution/solution-ecs-sts-token/code-example/python/oss_sdk/credentials_default_sample.py (22 lines of code) (raw):
# -*- coding: utf-8 -*-
import oss2
from alibabacloud_credentials.client import Client as CredClient
from alibabacloud_credentials.models import Config as CredConfig
from oss2 import CredentialsProvider
from oss2.credentials import Credentials
class ECSRoleCredentialDemo(CredentialsProvider):
def __init__(self, client):
self.client = client
def get_credentials(self):
cred = self.client.get_credential()
access_key_id = cred.get_access_key_id()
access_key_secret = cred.get_access_key_secret()
security_token = cred.get_security_token()
return Credentials(access_key_id, access_key_secret, security_token)
# 默认凭据链方式初始化Credentials客户端
# 请确保Credentials Python SDK(alibabacloud-credentials)版本>=0.3.5
cred = CredClient()
credentials_provider = ECSRoleCredentialDemo(cred)
# 填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
endpoint = 'https://oss-cn-hangzhou.aliyuncs.com'
# 填写Endpoint对应的Region信息,例如cn-hangzhou。
region = 'cn-hangzhou'
# 推荐使用更安全的V4签名算法。使用V4签名初始化时,除指定Endpoint以外,您还需要指定阿里云通用Region ID作为发起请求地域的标识
# OSS Python SDK 2.18.4及以上版本支持V4签名。
auth = oss2.ProviderAuthV4(credentials_provider)
service = oss2.Service(auth, endpoint, region=region)
# 列举当前账号下的存储空间。
for b in oss2.BucketIterator(service):
print(b.name)