您的位置:首页 >Python用代理安全调用OpenAI API教程
发布于2026-02-22 阅读(0)
扫一扫,手机访问

在进行OpenAI API请求时,有时出于网络环境限制、隐私保护或特定路由需求,我们需要通过代理服务器发送请求。然而,直接将代理地址配置到openai客户端的base_url参数中是常见的误区,这通常会导致407 Proxy Authentication Required等认证错误。base_url参数用于指定OpenAI API的端点,而非代理服务器。正确的方法是利用openai库底层支持的HTTP客户端配置代理。
openai Python库在内部使用了httpx作为其HTTP客户端。httpx库提供了强大的代理配置能力,包括对需要认证的代理的支持。因此,要正确配置代理,我们需要创建一个配置了代理的httpx.Client实例,并将其传递给OpenAI客户端。
为了提高代码的可移植性和安全性,避免将API密钥和代理URL等敏感信息硬编码到代码中,我们强烈建议使用.env文件来管理这些配置。
首先,在项目根目录下创建一个名为.env的文件,并添加以下内容:
OPENAI_API_KEY=sk-your_openai_api_key_here OPENAI_PROXY_URL=http://user:password@your_proxy_host:port
注意事项:
接下来,我们将编写Python代码来加载.env文件中的配置,并使用httpx配置OpenAI客户端。
首先,确保您的环境中安装了必要的库:
pip install openai httpx python-dotenv
然后,创建您的Python脚本:
import httpx
from openai import OpenAI
from dotenv import load_dotenv
import os
# 1. 加载 .env 文件中的环境变量
load_dotenv()
# 2. 从环境变量获取API密钥和代理URL
api_key = os.environ.get("OPENAI_API_KEY")
proxy_url = os.environ.get("OPENAI_PROXY_URL")
# 3. 根据是否存在代理URL初始化 OpenAI 客户端
if proxy_url:
# 如果存在代理URL,则创建一个配置了代理的 httpx.Client
# 并将其传递给 OpenAI 客户端的 http_client 参数
print(f"检测到代理配置,将使用代理: {proxy_url}")
# 增加超时时间以防代理响应慢,或网络延迟
http_client = httpx.Client(proxy=proxy_url, timeout=60.0)
client = OpenAI(api_key=api_key, http_client=http_client)
else:
# 如果没有代理URL,则直接初始化 OpenAI 客户端
print("未检测到代理配置,将不使用代理")
client = OpenAI(api_key=api_key)
# 4. 发起API请求
try:
completion = client.chat.completions.create(
model="gpt-3.5-turbo",
messages=[
{"role": "system", "content": "你是一位富有诗意的助手,擅长以创造性的方式解释复杂的编程概念。"},
{"role": "user", "content": "请用一首诗解释编程中的递归概念。"}
],
max_tokens=150, # 限制回答长度
temperature=0.7 # 调整创造性
)
print("\nAPI响应:")
print(completion.choices[0].message.content)
except Exception as e:
print(f"\nAPI请求失败: {e}")
# 进一步的错误处理,例如检查代理配置、网络连接等
代码解析:
通过本教程,您应该已经掌握了在Python中安全且正确地通过代理访问OpenAI API的方法。核心在于利用httpx库的代理功能,并将其集成到openai客户端中,同时辅以.env文件进行敏感信息的管理。遵循这些最佳实践,可以有效避免常见的代理配置错误,确保您的OpenAI API请求稳定可靠。
上一篇:App操作步骤详解
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9