[英]Download file from API and save/upload it to Google Storage using python
[英]Not able to upload/download files from Storage containers using python code
這是我們使用的 python 代碼,
這些文件將被訪問,然后上傳到存儲容器。
def az_upload_blob(tenantID, container_name, file_name, data):
try:
logger.debug("Info::Acessing uBlob.")
AZURE_STORAGE_CONNECTION_STRING = az_kv_getsecret(Con.KV_RINGR_URI, Con.KV_SEC_CONN_STRING)
blob_service_client = BlobServiceClient.from_connection_string(AZURE_STORAGE_CONNECTION_STRING)
blob_client = blob_service_client.get_blob_client(container=container_name, blob=file_name)
blob_client.upload_blob(data)
logger.debug("Info:: Blob uploaded")
except Exception as ex:
logger.error(f"uBlob:: {ex}")
raise Exception(f"AZ-uBlob-Exception: {ex}")
錯誤信息:
Server failed to authenticate the request. Make sure the value of Authorization header is formed correctly including the signature.
RequestId:23025256-801e-0047-3150-3b8ba5000000
Time:2021-04-27T10:34:18.1487489Z
ErrorCode:AuthenticationFailed
Error:None
AuthenticationErrorDetail:The MAC signature found in the HTTP request 'xyyz' is not the same as any computed signature. Server used following string to sign: 'PUT
636
application/octet-stream
*
x-ms-blob-type:BlockBlob
x-ms-client-request-id:1ebf24c8-a744-11eb-be9d-000d3a99de90
x-ms-date:Tue, 27 Apr 2021 10:34:18 GMT
x-ms-encryption-algorithm:AES256
x-ms-version:2020-06-12
請幫助解決丟失的項目。 謝謝!
更新:
我使用下面的代碼,它工作正常:
如果我運行 python 腳本,我首先運行“az login”,然后運行:
from azure.keyvault.secrets import SecretClient
from azure.identity import AzureCliCredential
from azure.storage.blob import BlobServiceClient
def az_upload_blob(KVUri,secretName, container_name, file_name, data):
try:
AZURE_STORAGE_CONNECTION_STRING = az_kv_getsecret(KVUri, secretName)
blob_service_client = BlobServiceClient.from_connection_string(AZURE_STORAGE_CONNECTION_STRING)
blob_client = blob_service_client.get_blob_client(container=container_name, blob=file_name)
blob_client.upload_blob(data)
except Exception as ex:
print("Some Exception.")
def az_kv_getsecret(KVUri,secretName):
credential = AzureCliCredential()
client = SecretClient(vault_url=KVUri, credential=credential)
retrieved_secret = client.get_secret(secretName)
print(retrieved_secret.value)
return retrieved_secret.value
KVUri = "https://bowmantest.vault.azure.net/"
secretName = "STR"
container_name = "test"
file_name = "0505test.txt"
data = "This is 0505test.txt"
az_upload_blob(KVUri=KVUri,secretName=secretName,container_name=container_name,file_name=file_name,data=data)
print("This is OK.")
If I use them in azure function, I just change the credential to 'ManagedIdentityCredential' and add the access policy of the function app to azure key vault(On my side, I give the full access.).
from azure.keyvault.secrets import SecretClient
from azure.identity import ManagedIdentityCredential
from azure.storage.blob import BlobServiceClient
def az_upload_blob(KVUri,secretName, container_name, file_name, data):
try:
AZURE_STORAGE_CONNECTION_STRING = az_kv_getsecret(KVUri, secretName)
blob_service_client = BlobServiceClient.from_connection_string(AZURE_STORAGE_CONNECTION_STRING)
blob_client = blob_service_client.get_blob_client(container=container_name, blob=file_name)
blob_client.upload_blob(data)
except Exception as ex:
print("Some Exception.")
def az_kv_getsecret(KVUri,secretName):
credential = ManagedIdentityCredential()
client = SecretClient(vault_url=KVUri, credential=credential)
retrieved_secret = client.get_secret(secretName)
print(retrieved_secret.value)
return retrieved_secret.value
KVUri = "https://bowmantest.vault.azure.net/"
secretName = "STR"
container_name = "test"
file_name = "0505test.txt"
data = "This is 0505test.txt"
az_upload_blob(KVUri=KVUri,secretName=secretName,container_name=container_name,file_name=file_name,data=data)
print("This is OK.")
原答案:
你能顯示 az_kv_getsecre 嗎? 事實上,我們總是只是從 azure blob 存儲中復制連接字符串。
格式應如下所示:
DefaultEndpointsProtocol=https;AccountName=youraccountname;AccountKey=xxxxxx;EndpointSuffix=core.windows.net
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.