Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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 openai-chatgpt
Last synced: 3 days ago
JSON representation
将ChatGPT网页转换成API接口。ChatGPT Web to API.
- Host: GitHub
- URL: https://github.com/adryfish/llm-web-api
- Owner: adryfish
- License: gpl-3.0
- Created: 2024-05-21T14:30:23.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-12-09T07:45:34.000Z (16 days ago)
- Last Synced: 2024-12-09T08:31:10.009Z (16 days ago)
- Topics: chatgpt, chatgpt-api, chatgpt-api-wrapper, openai, openai-api, openai-chatgpt
- Homepage:
- Size: 471 KB
- Stars: 64
- Watchers: 3
- Forks: 11
- Open Issues: 0
-
Metadata Files:
- Readme: README-ZH.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# LLM Web API
[![](https://img.shields.io/github/license/adryfish/llm-web-api.svg)](LICENSE)
![](https://img.shields.io/github/stars/adryfish/llm-web-api.svg)
![](https://img.shields.io/github/forks/adryfish/llm-web-api.svg)使用`Playwright`将网页版ChatGPT转换成`API`接口
## 功能列表
- 通过`Cloudflare`验证破解
- 登录模式支持免登录,邮箱登录和Google登录
- 高速流式输出
- 模型切换
- 动态显示支持模型与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
# 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 |
| 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**
请求数据:
```json
{
"model": "gpt-4o",
"messages": [
{
"role": "user",
"content": "Hello"
}
],
// 如果使用SSE流请设置为true,默认false
"stream": false
}
```响应数据:
```json
{
"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
}
}
```## 用例
### 使用Python OpenAI官方库
#### Python
```python
import openaiopenai.api_key = 'anything'
openai.base_url = "http://localhost:5000/v1/"completion = openai.chat.completions.create(
model="gpt-4o-mini",
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-mini',
});console.log(chatCompletion.choices[0].message.content);
```## 免责声明
本项目(以下简称“项目”)为公开分享的工具,旨在为用户提供便利和功能支持。使用本项目的所有风险由用户自行承担。
1. 本项目由开发者个人维护,不提供任何形式的保证,包括但不限于适销性、特定用途适用性、合法性或非侵权性的保证。
2. 使用本项目过程中产生的任何直接或间接后果,包括但不限于数据丢失、财产损失、业务中断或其他损害,开发者概不负责。
3. 用户应在遵守适用法律法规的前提下使用本项目,因用户不当使用或非法使用导致的后果与开发者无关。
4. 本项目中的内容可能包含第三方资源或链接,开发者对其内容的准确性、可靠性或合法性不作任何保证,也不对其造成的任何后果负责。
5. 用户在使用本项目的同时,视为已完全理解并接受上述声明内容。
若有任何疑问,请勿使用本项目。
## 同类项目
- chat2api: https://github.com/lanqian528/chat2api## Star History
[![Star History Chart](https://api.star-history.com/svg?repos=adryfish/llm-web-api&type=Date)](https://star-history.com/#adryfish/llm-web-api&Date)