Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zhuweiyou/chatgpt-api
封装 OpenAI 网页版最新 ChatGPT 接口, 不需要使用 API Key, 完全免费
https://github.com/zhuweiyou/chatgpt-api
chatgpt chatgpt-api
Last synced: 3 months ago
JSON representation
封装 OpenAI 网页版最新 ChatGPT 接口, 不需要使用 API Key, 完全免费
- Host: GitHub
- URL: https://github.com/zhuweiyou/chatgpt-api
- Owner: zhuweiyou
- Archived: true
- Created: 2023-02-23T10:18:26.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-05-27T02:57:08.000Z (over 1 year ago)
- Last Synced: 2024-08-01T08:16:56.256Z (6 months ago)
- Topics: chatgpt, chatgpt-api
- Language: JavaScript
- Homepage: https://zhuweiyou-chatgpt-api.vercel.app
- Size: 92.8 KB
- Stars: 350
- Watchers: 6
- Forks: 99
- Open Issues: 4
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# chatgpt-api
封装 OpenAI 网页版最新 ChatGPT 接口, 不需要使用 API Key, 完全免费
- - -
**_最近没有精力维护, 请移步以下项目_**
- [acheong08/OpenAIAuth](https://github.com/acheong08/OpenAIAuth) - 搭建 OpenAI 登录服务
- [pengzhile/pandora](https://github.com/pengzhile/pandora) - 搭建 OpenAI 反代网站
- [acheong08/ChatGPT](https://github.com/acheong08/ChatGPT) - 基于 Python 的 ChatGPT API
- [transitive-bullshit/chatgpt-api](https://github.com/transitive-bullshit/chatgpt-api) - 基于 Node.js 的 ChatGPT API
- - -
### 方式一
```bash
docker run -d -p 3000:3000 zhuweiyou/chatgpt-api:20230424
```### 方式二
安装 `nodejs 18.x` 环境
```bash
npm install --production
npm start
```程序会打印 `Listening on http://localhost:3000` 表示启动成功
### 方式三
Fork 本项目, 在 [vercel.com](https://vercel.com) 添加你自己的仓库, 创建一个 Node.js 应用, 即可一键完成部署
> vercel 的云函数免费版限制 10 秒超时, 回答很长的内容不一定好用, 还是建议部署到你自己机器
想要快速测试? 可以将文档中的 `BASE_URL` 更换成我部署在 vercel 的地址
## 使用文档
BASE_URL `http://localhost:3000`
POST Body 格式为 `x-www-form-urlencoded`
### 第一步: 获取网页版 access_token
#### 方式一: POST `/get_access_token` 登录获取
- `email` OpenAI 帐号 (不支持谷歌/微软授权登录)
- `password` OpenAI 密码成功响应
```json
{
"access_token": "token内容"
}
```![get_access_token截图](https://user-images.githubusercontent.com/8413791/230726142-7bc08fad-a46b-497b-be57-1ca4cd57e4f8.png)
获取成功之后建议缓存本地, 不用每次都调用获取
> 如果出现 `fetch failed` 大概率是墙了, 你也可以 Fork [zhuweiyou/chatgpt-auth](https://github.com/zhuweiyou/chatgpt-auth) 自建 auth 服务
#### 方式二: 如果方式一获取失败, 或者你是谷歌/微软帐号注册的 OpenAI, 可以手动登录获取
访问 成功登录之后, 打开浏览器开发者工具 (F12) -> 刷新页面- > Network
找到 `/api/auth/session` 请求, 复制 `accessToken` 存到你本地配置![截图](https://user-images.githubusercontent.com/8413791/225305658-188ec53c-c3ee-4ec6-9306-9ff9ce2c94af.png)
#### 方式三: 如果方式二你上不去官网, 可以尝试以下方式更简单获取
[点击这里获取 token](https://ai.fakeopen.com/auth)
### 第二步: 向 ChatGPT 提问
#### POST `/send_message`
不消耗免费额度, 也不需要花钱
- `access_token` 在 [第一步] 中获取的 access_token
- `prompt` 提问内容
- `model` 可选. 默认 `gpt-3.5-turbo`, 如果你是 ChatGPT Plus 账号可以传入 `gpt-4` 来切换模型
- `timeout` 可选. 超时时间(毫秒), 默认无限等待
- `conversation_id` 可选. 前一次 /send_message 的结果中返回, 用于上下文连续会话
- `parent_message_id` 可选. 前一次 /send_message 的结果中返回, 用于上下文连续会话
- `reverse_proxy` 可选. 反向代理服务器, 用于绕过 cloudflare 人机验证
1. `https://ai.fakeopen.com/api/conversation` (当前默认)
2. `https://api.pawan.krd/backend-api/conversation`#### 成功响应
```json
{
"text": "ChatGPT的回答",
"conversation_id": "xxx",
"parent_message_id": "yyy"
}
```![send_message截图](https://user-images.githubusercontent.com/8413791/226363534-5c856f41-1acb-4615-bcbd-b169d3f294e1.png)
### 以上所有 API 失败响应
HTTP Status Code: 500
```json
{
"message": "错误消息"
}
```