在軟體開發中,代理就像是一個“中間人”,它幫我們控制對某個功能或資源的訪問。使用代理可以實現許可權檢查、記錄動作記錄、快取資料、消極式載入等功能,而不用改動原來的代碼。這樣可以讓程式更安全、運行更快,也更容易維護和擴充。本文為您介紹V2.0 Python SDK對於網路代理程式的配置方式。
代理類型
支援使用HTTP代理和HTTPS代理。
代理類型 | 描述 |
HTTP代理 | 通過參數http_proxy配置Proxy 伺服器地址和連接埠,格式為: |
HTTPS代理 | 通過參數https_proxy配置Proxy 伺服器地址和連接埠,格式為: |
若Proxy 伺服器要求身份認證才能進行訪問,請在IP地址前添加Proxy 伺服器配置的使用者名稱和密碼,格式為:http://<user>:<password>@<IP地址>:<連接埠>
此外,在配置代理後,也可通過參數no_proxy指定無需通過代理訪問的地址清單,多個地址之間用逗號分隔,支援網域名稱和IP地址格式。
代理配置方式
代理配置優先順序為:RuntimeOptions配置 -> Config配置 -> 環境變數配置,優先順序依次降低。
通過環境變數配置代理:
說明不支援在環境變數中配置
no_proxy。通過環境變數參數HTTP_PROXY或http_proxy指定Proxy 伺服器地址。
通過環境變數參數HTTPS_PROXY或https_proxy指定Proxy 伺服器地址。
通過運行時參數(RuntimeOptions)配置代理,僅對使用了該運行時參數的請求有效。
from alibabacloud_tea_openapi.models import Config from alibabacloud_tea_util.models import RuntimeOptions config = Config( protocol='https', # 請求協議與HTTP代理配置參數有關,httpsProxy僅對https協議有效,httpProxy僅對http協議有效。 ) # 在RuntimeOptions中配置代理 runtimeOptions = RuntimeOptions( http_proxy='http://127.0.0.1:9898', https_proxy='http://127.0.0.1:8989', no_proxy='127.0.0.1,localdomain.com' )在初始化用戶端階段,通過Config類配置代理,對所有請求都生效。
from alibabacloud_tea_openapi.models import Config config = Config( protocol='https', # 請求協議與HTTP代理配置參數有關,httpsProxy僅對https協議有效,httpProxy僅對http協議有效。 # 代理配置 http_proxy='http://127.0.0.1:9898', https_proxy='http://127.0.0.1:8989', no_proxy='127.0.0.1,localdomain.com' )
相關文檔
代理配置相關實踐文檔,請參見HTTP代理配置實踐。