使用 Blob 服务客户端查找 azure 帐户密钥失败(azure python sdk)

Posted

技术标签:

【中文标题】使用 Blob 服务客户端查找 azure 帐户密钥失败(azure python sdk)【英文标题】:Finding the azure account key with Blob Service Client fails(azure python sdk) 【发布时间】:2021-02-24 14:02:35 【问题描述】:

我正在使用 名称:天蓝色管理存储 版本:16.0.0 摘要:适用于 Python 的 Microsoft Azure 存储管理客户端库 主页:https://github.com/Azure/azure-sdk-for-python

用于生成报告以查找存储容器大小。 我正在使用的代码的 sn-p 如下

from azure.mgmt.storage import StorageManagementClient

subscription_client = Subscription(tenant=tenant_id, client_id=client_id, secret=client_secret)
service_principals = subscription_client.credentials
subscription_id = subscription_client.find_subscription_id()
storage_client = StorageManagementClient(credential=service_principals, subscription_id=subscription_id)
storage_account_list = storage_client.storage_accounts.list()
for storage_account in storage_account_list:
    blob_service_client = BlobServiceClient(account_url=storage_account.primary_endpoints.blob,credential=service_principals)
                    account_info = blob_service_client.get_service_properties()
    keys = blob_service_client.credential.keys()

当我评估表达式 blob_service_client.credential 时,值为

<azure.identity._credentials.client_secret.ClientSecretCredential object at 0x05747E98>

    blob_service_client.api_version 计算结果为 2020-02-10

    blob_service_client.credential.account_keyblob_service_client.credential.account_key() 的计算结果为AttributeError'ClientSecretCredential' object has no attribute 'account_key'

    甚至当我尝试blob_service_client.credential.keys() 时,我得到AttributeError'ClientSecretCredential' object has no attribute 'keys' 错误

有任何 Azure 专家可以帮助我吗?连接字符串也是解决此问题的另一种方法,我可以使用:

BlobServiceClient.from_connection_string(connection_string)

我还需要动态生成connection_string,但我无法做到。

【问题讨论】:

【参考方案1】:

由于您已经在使用客户端机密凭证,您可以进行存储操作(在这种情况下计算存储容器大小)。请注意,在我的代码下面,我已经有了方便的订阅 ID,所以我没有使用订阅客户端。但是您绝对可以喜欢您的原始代码。

from azure.identity import ClientSecretCredential
from azure.mgmt.storage import StorageManagementClient
from azure.storage.blob import BlobServiceClient, ContainerClient

tenant_id='<tenant id>'
client_id='<client id>'
client_secret='<secret>'
subscription_id='<subscription id>'

credentials = ClientSecretCredential(tenant_id=tenant_id, client_id=client_id, client_secret=client_secret)
storage_client = StorageManagementClient(credential=credentials, subscription_id=subscription_id)
storage_account_list = storage_client.storage_accounts.list()
for storage_account in storage_account_list:
    blob_service_client = BlobServiceClient(account_url=storage_account.primary_endpoints.blob,credential=credentials)
    containers = blob_service_client.list_containers()
    for container in containers:
        container_client = ContainerClient(account_url=storage_account.primary_endpoints.blob,credential=credentials, container_name=container.name)
        blobs = container_client.list_blobs()
        container_size = 0
        for blob in blobs:
            container_size = container_size + blob.size
        print('Storage Account: ' + storage_account.name + ' ; Container: ' + container.name + ' ; Size: ' + str(container_size))

【讨论】:

感谢您的回答。我可以使用 storage_client.storage_account.list_keys(resource_group_name, account_name) 访问密钥。键。链接如下:github.com/Azure/azure-sdk-for-python/blob/… 还有凭证对象太错误我使用密钥作为创建容器客户端所需的位置参数凭证。如果您可以将凭据的值更改为 key1,那么我可以接受您的回答。或者,您可以提供一种替代方式来提供凭据,因为它可以帮助其他用户。 “凭据对象也有太多错误” - 你能具体谈谈你观察到的问题吗? 将很快发布一个单独的问题

以上是关于使用 Blob 服务客户端查找 azure 帐户密钥失败(azure python sdk)的主要内容,如果未能解决你的问题,请参考以下文章

使用服务帐户从 Azure Blob 存储中批量删除文件

Azure 存储帐户:Blob 服务 (SAS) 连接检查失败

Azure 门户在存储帐户中创建 Blob 容器时出错

在 Azure 存储中查找软删除 blob 的永久删除日期

Azure 使用 REST api 和托管标识创建 blob 容器 - 403 错误

使用 azure 逻辑应用将 blob 从 azure 存储帐户动态发送到电子邮件