Share via


Konfigurera proxyservrar för Azure SDK för Python

Om din organisation kräver att en proxyserver används för att komma åt Internetresurser måste du ange en miljövariabel med proxyserverinformationen för att använda Azure SDK för Python. Om du anger miljövariablerna (HTTP_PROXY och HTTPS_PROXY) används proxyservern vid körning av Azure SDK för Python.

En proxyserver-URL har formuläret http[s]://[username:password@]<ip_address_or_domain>:<port>/ där kombinationen av användarnamn och lösenord är valfri.

Du kan sedan konfigurera en proxy globalt med hjälp av miljövariabler, eller så kan du ange en proxy genom att skicka ett argument med namnet proxies till en enskild klientkonstruktor eller åtgärdsmetod.

Global konfiguration

Om du vill konfigurera en proxy globalt för skriptet eller appen definierar HTTP_PROXY du eller HTTPS_PROXY miljövariabler med serverns URL. Dessa variabler fungerar med valfri version av Azure-biblioteken. Observera att HTTPS_PROXY det inte betyder HTTPS proxy, utan proxy för https:// begäranden.

Dessa miljövariabler ignoreras om du skickar parametern use_env_settings=False till en klientobjektkonstruktor eller åtgärdsmetod.

Ange från kommandoraden

rem Non-authenticated HTTP server:
set HTTP_PROXY=http://10.10.1.10:1180

rem Authenticated HTTP server:
set HTTP_PROXY=http://username:password@10.10.1.10:1180

rem Non-authenticated HTTPS server:
set HTTPS_PROXY=http://10.10.1.10:1180

rem Authenticated HTTPS server:
set HTTPS_PROXY=http://username:password@10.10.1.10:1180

Ange i Python-kod

Du kan ange proxyinställningar med hjälp av miljövariabler, utan att det behövs någon anpassad konfiguration.

import os
os.environ["HTTP_PROXY"] = "http://10.10.1.10:1180"

# Alternate URL and variable forms:
# os.environ["HTTP_PROXY"] = "http://username:password@10.10.1.10:1180"
# os.environ["HTTPS_PROXY"] = "http://10.10.1.10:1180"
# os.environ["HTTPS_PROXY"] = "http://username:password@10.10.1.10:1180"

Anpassad konfiguration

Ange i Python-kod per klient eller per metod

För anpassad konfiguration kan du ange en proxy för ett specifikt klientobjekt eller en åtgärdsmetod. Ange en proxyserver med ett argument med namnet proxies.

Följande kod från artikeln Exempel: Använd Azure Storage anger till exempel en HTTPS-proxy med användarautentiseringsuppgifter med BlobClient konstruktorn. I det här fallet kommer objektet från azure.storage.blob-biblioteket, som baseras på azure.core.

from azure.identity import DefaultAzureCredential

# Import the client object from the SDK library
from azure.storage.blob import BlobClient

credential = DefaultAzureCredential()

storage_url = "https://<storageaccountname>.blob.core.windows.net"

blob_client = BlobClient(storage_url, container_name="blob-container-01",
    blob_name="sample-blob.txt", credential=credential,
    proxies={ "https": "https://username:password@10.10.1.10:1180" }
)

# Other forms that the proxy URL might take:
# proxies={ "http": "http://10.10.1.10:1180" }
# proxies={ "http": "http://username:password@10.10.1.10:1180" }
# proxies={ "https": "https://10.10.1.10:1180" }