/chat2api

A service that can convert ChatGPT on the web to OpenAI API format.

Primary LanguagePythonMIT LicenseMIT

CHAT2API

🤖 一个简单的ChatGPT TO API代理

🌟 无需账号即可使用免费、无限的 GPT-3.5

💥 支持AccessToken使用账号,支持 GPT-4GPT-4o

🔍 回复格式与真实api完全一致,适配几乎所有客户端

交流群

https://t.me/chat2api

功能

已完成

  • 免登录 GPT3.5
  • 使用 AccessToken
  • GPT3.5 对话 (传入模型名不包含gpt-4,则默认使用gpt-3.5,也就是text-davinci-002-render-sha)
  • GPT4.0 对话 (传入模型名包含: gpt-4,gpt-4o,gpt-4-moblie 即可使用对应模型)
  • Tokens 计算
  • Stream 流式传输
  • 配置 PROXY 代理
  • 配置 BASE_URL
  • 外置 ArkoseToken
  • 使用 RefreshToken 代替 AccessToken
  • 反向代理 UI (http://127.0.0.1:5005, 不支持登录使用)
  • GPT4.0 画图、工具 (beta)
  • 支持 WSS (beta)
  • 返回 conversation_id (beta)
  • 支持GPTs (传入模型名:gpt-4-gizmo-g-*)
  • 上传图片、文件 (格式为API对应格式,支持url和base64)

TODO

  • claude2api
  • 暂无,欢迎提 issue

部署

(推荐) zeabur部署

Deploy on Zeabur

直接部署

git clone https://github.com/LanQian528/chat2api
cd chat2api
pip install -r requirements.txt
python app.py

Docker部署

您需要安装Docker和Docker Compose。

docker run -d \
  --name chat2api \
  -p 5005:5005 \
  lanqian528/chat2api:latest

(推荐,可用4.0) Docker Compose部署

创建一个新的目录,例如chat2api,并进入该目录:

mkdir chat2api
cd chat2api

在此目录中下载库中的docker-compose.yml文件:

wget https://raw.githubusercontent.com/LanQian528/chat2api/main/docker-compose.yml

修改docker-compose.yml文件中的环境变量,保存后:

docker-compose up -d

使用

  • 在网页使用, 直接访问以下地址, 仅支持使用免登 GPT3.5:
http://127.0.0.1:5005
  • 使用 API , 支持传入 AccessToken 或 RefreshToken, 可用 GPT4.0:
curl --location 'http://127.0.0.1:5005/v1/chat/completions' \
--header 'Content-Type: application/json' \
--data '{
     "model": "gpt-3.5-turbo",
     "messages": [{"role": "user", "content": "Say this is a test!"}],
     "stream": true
   }'

常见问题

  • 错误代码:
    • 401:当前IP不支持免登录,请尝试更换IP地址,或者在环境变量 PROXY_URL 中设置代理。
    • 403:当前IP地址被 CF 盾拦截,请尝试更换IP地址,或者在环境变量 PROXY_URL 中设置代理。
    • 429:当前IP请求1小时内请求超过限制,请稍后再试,或更换ip。
    • 500:服务器内部错误,请求失败。
    • 502:服务器网关错误,或网络不可用,请尝试更换网络环境。

使用GPT4

目前支持外部服务提供 ArkoseToken

推荐使用 docker-compose 方式部署, 已内置 Arkose 服务

  1. 设置环境变量ARKOSE_TOKEN_URL

  2. 在需要ArkoseToken的时候,chat2api会向ARKOSE_TOKEN_URL发送POST请求

  3. 请按照以下格式提供外部服务:

  • 请求体:
{
    "blob": "rFYaxQNEApDlx/Db.KyrE79pAAFBs70CYtbM4pMNUsc7jIkLGdiDs7vziHRGe78bqWXDo0AYyq2A10qIlcTt89lBYXJqCbONC/nD8C199pEZ/c9ocVKKtM27jZQ7fyOpWd9p5qjKeXT4xEGBFpoE3Re1DwdQeijYp7VMJQyw7RYN+IDB1QEx3aKSO6aTI+ivnhw9ztfn/p1SkvAyyOhur/ArF08WQ+rXQpxpttaSQlzMsIwlYbuUUuYE2f9JrQaYG7qip1DKvju111P6wTNy4QVlMXG32VrzaOWh4nmQ0lOcZ1DmN6u2aeJZotffHV2zOOQAqqnParidTbN+qFre2t77ZwBuGKGqLyT8LeOp02GdFwcyw0kkeX+L7vwYAzBpjA5ky0r0X+i8HpzWt8QCyWzEW9kHn9LLCTwg2MOumzjb66Ad4WDe+C1bAcOKuEyXiYh+a1cWZAOdzEuxEg90yCfI7DZR94BsoDR85gEC/Og88i098u5HV7hZZEOQ6J8fmi68FSyPkN7oLCmBsZCMAZqzapNP/MkeIMExrdw7Jf/PtMrZN4bwM56mWfyIJf5h/zXu8PUajVwE9Pj/M5VtB0spZg49JNeHExosVCAB0C0JW+T8vEIwoqiY4pRQ0lbMHTQZFpU2xURTgcgh+m6g1SEYR1FY3de1XnzfiTQq1RTNJPydj5xpt6r6okr8yIJdRhmVXlQI+pS7vi3+Lls2hnpr7L+l1mcUIMPZNBCs3AUFJNpp6SwQjZkPvKggg1p+uS6PdvKRizM9O9+FKc103AhuSia8KTrvU8tWhBhCzIHCD4LNfnkjuBWSdbDttva4AEXUoPuKkQCWaBzq4lQPUIHFOM9HmNe738vVkNdAuOYffxDNegcpIxLVgZGfbgLQ="
}
  • 响应体:
{
    "token": "45017c7bb17115f36.7290869304|r=ap-southeast-1|meta=3|metabgclr=transparent|metaiconclr=%23757575|guitextcolor=%23000000|pk=0A1D34FC-659D-4E23-B17B-694DCFCF6A6C|at=40|sup=1|rid=3|ag=101|cdn_url=https%3A%2F%2Ftcr9i.openai.com%2Fcdn%2Ffc|lurl=https%3A%2F%2Faudio-ap-southeast-1.arkoselabs.com|surl=https%3A%2F%2Ftcr9i.openai.com|smurl=https%3A%2F%2Ftcr9i.openai.com%2Fcdn%2Ffc%2Fassets%2Fstyle-manager"
}

高级设置

默认情况都不需要设置,除非你有需求

环境变量

每个环境变量都有默认值,如果不懂环境变量的含义,请不要设置

API_PREFIX=your_prefix                               // API前缀,设置后需请求 http://127.0.0.1:5005/your_prefix/v1/chat/completions
AUTHORIZATION=your_first_key, your_second_key        // 使用免登3.5的Bearer token,不设置则无需Bearer token (不是 AccessToken)
CHATGPT_BASE_URL=https://chat.openai.com             // ChatGPT网关地址,设置后会改变请求的网站,多个网关用逗号分隔
HISTORY_DISABLED=true                                // 是否不保存聊天记录并返回 conversation_id,true为不保存且不返回
PROXY_URL=your_first_proxy, your_second_proxy        // 代理url,多个代理用逗号分隔
ARKOSE_TOKEN_URL=https://arkose.example.com/token    // 获取Arkose token的地址,上文有提供说明
RETRY_TIMES=3                                        // 出错重试次数

License

MIT License