solution/solution-ack-sts-token/code-example/python/oss_sdk/credentials_default_sample.py (21 lines of code) (raw):
import oss2
from oss2 import CredentialsProvider
from oss2.credentials import Credentials
from alibabacloud_credentials.client import Client as CredentialsClient
class CredentialProviderWarpper(CredentialsProvider):
def __init__(self, client):
self.client = client
def get_credentials(self):
credential = self.client.get_credential()
access_key_id = credential.access_key_id
access_key_secret = credential.access_key_secret
security_token = credential.security_token
return Credentials(access_key_id, access_key_secret, security_token)
# 初始化Credentials客户端
# 请确保Credentials Python SDK(alibabacloud-credentials)版本>=0.3.5
cred = CredentialsClient()
# 使用凭据初始化OSSClient
credentials_provider = CredentialProviderWarpper(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)