https://github.com/adryfish/llm-web-api
将ChatGPT网页转换成API接口。ChatGPT Web to API.
https://github.com/adryfish/llm-web-api
chatgpt chatgpt-api chatgpt-api-wrapper openai openai-api
Last synced: about 1 month ago
JSON representation
将ChatGPT网页转换成API接口。ChatGPT Web to API.
- Host: GitHub
- URL: https://github.com/adryfish/llm-web-api
- Owner: adryfish
- License: apache-2.0
- Created: 2024-05-21T14:30:23.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2025-02-19T14:53:04.000Z (3 months ago)
- Last Synced: 2025-04-02T11:01:42.824Z (about 2 months ago)
- Topics: chatgpt, chatgpt-api, chatgpt-api-wrapper, openai, openai-api
- Homepage:
- Size: 24.4 KB
- Stars: 83
- Watchers: 2
- Forks: 12
- Open Issues: 1
-
Metadata Files:
- Readme: README-ZH.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# LLM Web API
[](LICENSE)

使用`Playwright`将网页版ChatGPT转换成`API`接口
## 功能列表
- 通过`Cloudflare`验证破解
- 登录模式支持免登录、邮箱登录和Google登录
- 高速流式输出
- 模型切换,动态显示支持模型
- 对话支持
- TTS支持(文本转语音支持)与ChatGPT接口完全兼容。
## 使用方法
### 使用Docker运行
```shell
docker run --name llm-web-api --rm -it -p 5000:5000 adryfish/llm-web-api
```### 使用Docker compose
详细配置见下方环境变量
```yml
services:
llm-web-api:
image: adryfish/llm-web-api
container_name: llm-web-api
ports:
- "5000:5000"
volumes:
# 浏览器数据,如何要保留浏览器登录信息,需要配置
- ./data:/app/data
environment:
# PROXY_SERVER: "" # 代理服务器地址
# OPENAI_LOGIN_TYPE: "" # 登录类型,nologin or email或者google
# OPENAI_LOGIN_EMAIL: "" # 登录邮箱
# OPENAI_LOGIN_PASSWORD: "" # 登录密码
restart: unless-stopped
```### 环境变量
所有的环境变量均为可选。
| 变量名 | 描述 | 默认值 |
|-----------------------|----------------------------------------|--------|
| PROXY_SERVER | 代理服务器地址 | None |
| DATA_DIR | 数据存放目录 | 当前目录/data |
| OPENAI_LOGIN_TYPE | ChatGPT 的登录类型, nologin, email, google | nologin|
| OPENAI_LOGIN_EMAIL | 对于 email 登录方式,提供 email 帐号 | None |
| OPENAI_LOGIN_PASSWORD | 对于 email 登录方式,提供密码 | None |
| OPENAI_LOGIN_APP_PASSWORD | app password(非必须) | None |
| GOOGLE_LOGIN_EMAIL | google登录邮箱 | None |
| GOOGLE_LOGIN_PASSWORD | google登录邮箱密码 | None |
| GOOGLE_LOGIN_OTP_SECRET | google登录二次认证secret | None |
| GOOGLE_LOGIN_RECOVERY_EMAIL | google登录恢复邮箱 | None |## 原理
使用`Playwright`控制指纹浏览器,模拟用户操作,发送请求到OpenAI网页, 将响应转换成API接口。## 接口列表
目前支持与openai兼容的 `/v1/chat/completions` 接口,可自行使用与openai或其他兼容的客户端接入接口
### 对话补全
对话补全接口,与openai的 [chat-completions-api](https://platform.openai.com/docs/api-reference/chat) 兼容。
**POST /v1/chat/completions**
请求数据:
```jsonc
{
"model": "gpt-4o",
"messages": [
{
"role": "user",
"content": "Hello"
}
],
// 可选: 如果使用SSE流请设置为true,默认false
"stream": false
// 可选: 如果启用,响应中将包含元数据 (message_id 和 conversation_id)
// 如果同时提供 parent_message_id 和 conversation_id,则请求将在现有对话上下文中继续。
// 如果未设置,则请求将被视为新的对话。
// "meta": {
// "enable": true,
// "parent_message_id": "5363437e-b364-4b72-b3d6-415deeed11ab", # 可选
// "conversation_id": "6774f183-f70c-800b-9965-6c110d3a3485" # 可选
// }
}
```响应数据:
```jsonc
{
"id": "chatcmpl-fZc6l869OzRu8rp7X8Dhj0COfTsR6",
"object": "chat.completion",
"created": 1733726226,
"model": "gpt-4o",
"choices": [
{
"index": 0,
"message": {
"role": "assistant",
"content": "Hi there! How can I assist you today? 😊"
},
"logprobs": null,
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 1,
"completion_tokens": 11,
"total_tokens": 12
},
// 如何没有设置ENABLE_REQUEST_METADATA=True,则不会有meta数据返回
"meta": {
"message_id": "dffd63ef-63ac-4d40-b6de-e33ec40de9e2",
"conversation_id": "6774f183-f70c-800b-9965-6c110d3a3485"
}
}
```### 语音合成API
语音合成API,与OpenAI的 [Audio Speech API](https://platform.openai.com/docs/api-reference/audio) 兼容。允许用户将文本转换为语音。
**POST /v1/audio/speech**
请求数据:
```jsonc
{
"input": "你好,你今天怎么样?",
"voice": "cove",
"model": "tts-1",
// 可选:指定返回格式,默认为 "aac"
"response_format": "mp3"
}
```响应数据:
如果请求成功,API 将返回所请求格式的音频文件。
## 用例
### 使用Python OpenAI官方库
#### Python
```python
import openaiopenai.api_key = 'anything'
openai.base_url = "http://localhost:5000/v1/"completion = openai.chat.completions.create(
model="gpt-4o",
messages=[
{"role": "user", "content": "Hello"},
],
)print(completion.choices[0].message.content)
```#### Node.js
```javascript
import OpenAI from 'openai';const openai = new OpenAI({
apiKey: "anything",
baseURL: "http://localhost:5000/v1/",
});const chatCompletion = await openai.chat.completions.create({
messages: [{ role: 'user', content: 'Echo Hello' }],
model: 'gpt-4o',
});console.log(chatCompletion.choices[0].message.content);
```## 同类项目
- chat2api: https://github.com/lanqian528/chat2api## Star History
[](https://star-history.com/#adryfish/llm-web-api&Date)