国内如何访问 OpenAI 的 api

这个问题甚至我的一些大厂的朋友也不太清楚,所以我觉得有必备写一篇文章来简单盘盘它,希望能帮助到有需要的人

众所周知,由于大陆与 OpenAI 双方互相封锁,大陆是无法直接访问 OpenAI api 的

不过由于 GPT 4 的统治地位,国内很 AI 应用都首选 OpenAI,那么问题来了,这些应用该怎么访问 OpenAI 的 api 呢

其实主要有两种方式

1. 通过代理

大陆无法直接访问 OpenAI,那我能不能通过一种间接的方式来访问 OpenAI 呢

学习 HTTP 时我们都学过代理的概念,我们可以先把请求打到这个代理上,再由这个代理把请求转发到 OpenAI,这样就可以访问 OpenAI 了

ba29341209b50fb11c3125ab5a333c37.png

代理只是起到了一个转发流量的作用,所以除了 host 外,其他像 query,body 等与直接访问 OpenAI api 无异,这样使用者只需要把 host 替换一下(比如把 api.openai.com 换成 api.openai-proxy.com),其他请求格式不变,就可访问 OpenAI 的 api 了,很方便

当然了这个代理国内必须可以访问,比如 Cloudflare,DigitalOcean 等平台上的 server 都可以充当代理

那有人可能会问了,为了访问 OpenAI,我得额外花钱搭一个这样的代理,好像也有点不划算呢

你想到的别人也考虑好啦,目前市面上已经有一些搭建好的代理了,如 api.openai-proxy.com,你在使用的时候把 host 替换成这个,其他不变就可正常使用啦

当然了,第三方代理存在一定的安全隐患,比如虽然第三方代理号称只是转发,不保留数据,但谁知道呢,如果你的业务对安全性要求很高,估计自建代理才是最佳选择

2. 通过 vercel 等云服务平台

vercel 是全球非常知名的一个免费网站托管平台,无论是动态(如 api 服务)还是静态网站都可免费部署,而且部署非常方便,是很多开发者的首选

我们可以先把访问 OpenAI api 的服务部署在 vercel 上,但是问题来了,部署在 vercel 上的应用(通常是 xxx.vercel.app)国内也是没法访问的,那该怎么办?

这里就需要简单了解一下 HTTP 和 DNS 的原理了

假设我有一个域名叫 api.example.com,这个域名在国内是可以访问的,我想在访问这个域名时,最终经过 DNS 解析后打到的是我部署在 vercel 上的 访问 OpenAI 的 api 应用,该怎么办

实际上只要在访问 api.example.com 时解析出 vercel 平台上的 IP ,然后再通过 IP 来访问部署在 vercel 平台上的应用即可

那怎样才能在访问 api.example.com 时解析出 vercel 平台上的 IP 呢,答案是 CNAME(以下的记录值 cname.vercel-dns.net. 是我随便写的,实际上 vercel 提供了另一个正确的可被国内 DNS 解析的域名,比较敏感,不方便放,网上可找到哦)

07c49f620a8adbaaa5694d74fc49aa09.png

通过以上的记录值就可最终解析出 vercel 平台上的 IP,假设为 76.86.22.62(能解析出 IP 的原因在于 cname.vercel-dns.net. 可正常被解析,现在你知道为啥我要放这样一个随便写的值了吧,有风险)

注意这只是 vercel 平台的对外 IP,光凭 IP 是无法确定要打到哪个应用的,IP+Host 才可以哦

a14749e484ccd362443b32283406c5a0.png

所以我们要在 vercel 上的应用设置中先配置一下域名

1bab498c952c51b1bf08ae5a57b4be31.png

这样请求的时候有了 IP,有了 host:api.example.com,通过 api.example.com 访问的流量就可以转发到正确的应用上来啦

4a5d1ccc39cda707a27901e18b295289.jpeg

### 关于硅基流动APIOpenAI集成使用指南 #### 3.1 硅基流动API简介 硅基流动提供了强大的API接口,允许开发者轻松调用其预训练的语言模型服务。这些服务涵盖了多种自然语言处理任务,如文本嵌入、语义相似度计算等。为了更好地支持开发者的应用需求,硅基流动还特别优化了与中国本土环境相适应的功能特性[^2]。 #### 3.2 OpenAI API概述 OpenAI 提供了一系列先进的人工智能工具和服务,其中最著名的是GPT系列大语言模型。除了提供完整的在线访问外,OpenAI同样开放了一套RESTful风格的HTTP API给外部开发者用于集成到自有应用程序中去。这使得任何拥有有效API密钥的人都可以方便地请求来自云端服务器端的大规模机器学习算法运算结果[^1]。 #### 3.3 集成步骤说明 ##### Python代码实现示例 下面是一个简单的Python脚本例子,展示了如何同时利用硅基流动和OpenAI两家服务商所提供的API来进行文档向量化表示: ```python import os from dbgpt.rag.embedding import OpenAPIEmbeddings # 初始化硅基流动embedding对象 openai_embeddings = OpenAPIEmbeddings( api_url="https://api.siliconflow.cn/v1/embeddings", api_key=os.getenv("SILICONFLOW_API_KEY"), model_name="BAAI/bge-large-zh-v1.5" ) texts = ["Hello, world!", "How are you?"] res_siliconcloud = openai_embeddings.embed_documents(texts) print("SiliconCloud embeddings:", res_siliconcloud) # 假设这里也有一个对应的初始化方法来创建OpenAI的embeddings实例 # 这里仅作为示意并未给出具体实现细节 openai_embedding_instance = initialize_openai_embedder() res_openai = openai_embedding_instance.embed_documents(texts) print("OpenAI embeddings:", res_openai) ``` 此段程序首先定义了一个`OpenAPIEmbeddings`类的对象,该对象被用来封装对硅基流云平台上的特定版本中文BERT模型(`model_name`)发起远程过程调用所需的一切参数设置;接着传入待转换为固定长度特征向量形式的一组字符串列表并执行实际的数据传输逻辑;最后打印输出得到的结果以便观察对比不同来源产生的差异之处。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值