将 Google Antigravity API 转换为 OpenAI 兼容格式的代理服务,支持流式响应、工具调用、多账号管理和完整的用户管理系统。
测试地址 https://ggt333.zeabur.app/user.html
这个错误是 redirect_uri_mismatch,意思是 Google OAuth 的回调地址不匹配。 原因:你需要在 Google Cloud Console 中添加正确的重定向 URI。 解决方法: 打开 Google Cloud Console 进入 APIs & Services → Credentials 找到你的 OAuth 2.0 Client ID,点击编辑 在 Authorized redirect URIs 中添加你的回调地址: 如果是本地开发:http://localhost:端口/admin/oauth-callback 如果是生产环境:https://你的域名/admin/oauth-callback 查看当前使用的 redirect_uri: 你可以看一下浏览器地址栏中 Google 授权页面的 URL,找到 redirect_uri= 参数,把那个值添加到 Google Cloud Console 中。
- ✅ OpenAI API 完全兼容格式
- ✅ 流式和非流式响应
- ✅ 工具调用(Function Calling)支持
- ✅ 多账号自动轮换
- ✅ Token 自动刷新
- ✅ API Key 认证
- ✅ 思维链(Thinking)输出
- ✅ 图片输入支持(Base64 编码)
- 🎛️ Web管理后台 - 完整的可视化管理界面
- 👥 用户系统 - 用户注册、登录、API密钥管理
- 🔑 密钥管理 - API密钥生成、频率限制
- 📢 公告系统 - 系统公告发布和管理
- 📊 模型配额 - 每日模型使用限制
- 🔐 安全防护 - IP/设备封禁、注册限制
- 🌐 Token共享中心 - 用户可共享自己的Token供社区使用
- 🚫 滥用防护 - 自动检测和封禁滥用用户
- 🗳️ 社区投票 - 社区投票封禁滥用者
- 📈 使用统计 - 实时显示每个用户的使用情况
- ⚫ 黑名单系统 - Token所有者可屏蔽特定用户
- 🔍 智能分析 - AI自动分析用户使用模式
- ⚡ 自动封禁 - 基于AI判断自动封禁异常用户
- ⏱️ 定时任务 - 可配置每小时自动审核
- 📊 详细日志 - 完整的审核历史和决策记录
- 🎯 置信度控制 - 可调整自动封禁阈值
- Node.js >= 18.0.0
- pnpm 或 npm
pnpm install
# 或
npm install编辑 config.json 配置服务器和 API 参数:
{
"server": {
"port": 8045,
"host": "0.0.0.0"
},
"security": {
"apiKey": "sk-text",
"adminPassword": "admin123",
"maxRequestSize": "50mb"
},
"defaults": {
"temperature": 1,
"top_p": 0.85,
"top_k": 50,
"max_tokens": 8096
}
}pnpm dev
# 或
npm run dev服务将在 http://localhost:8045 启动。
打开浏览器访问 http://localhost:8045,使用配置的管理员密码登录。
- 添加/删除 Google Token
- 查看 Token 使用统计
- 启用/禁用 Token
- 导入/导出 Token
- 生成管理员 API 密钥
- 设置密钥频率限制(每分钟/每小时/每天)
- 查看密钥使用统计
- 查看所有注册用户
- 启用/禁用用户
- 查看用户Token和使用情况
- 设置用户模型配额
- 查看用户共享统计
- 创建/编辑/删除公告
- 设置公告优先级
- 启用/禁用公告
- 从Google获取最新模型列表
- 设置默认模型配额
- 查看每个模型的使用统计
- 实时请求统计
- 系统资源使用
- Token使用情况
- 错误日志查看
访问 http://localhost:8045/user.html 进入用户中心:
- 账号注册/登录 - 独立的用户系统
- API密钥管理 - 生成个人API密钥
- Token管理 - 添加/共享自己的Google Token
- 使用统计 - 查看个人使用情况
- 模型配额 - 查看每日模型使用限额
访问 http://localhost:8045/share.html 进入共享中心:
- Token列表 - 查看所有共享的Token及可用额度
- 用户统计 - 查看所有用户的使用排行
- 平均日使用量
- 今日使用量
- 最大日使用量
- 使用天数统计
- 异常用户标识
- 投票封禁 - 发起或参与封禁投票
- 投票历史 - 查看所有投票记录
在管理后台的"AI 管理"标签页配置:
- 启用AI审核 - 开启/关闭自动审核
- API端点 - AI服务的API地址
- API密钥 - AI服务的认证密钥
- 模型 - 使用的AI模型(如 gemini-2.0-flash-exp)
- 检查间隔 - 审核频率(1-24小时)
- 置信度阈值 - 自动封禁的最低置信度(0-1)
- 系统提示词 - AI分析的指导规则
系统默认分析以下指标:
- 使用频率 - 平均每天超过50次为异常
- 使用模式 - 短时间内大量请求
- 时间分布 - 24小时持续高频使用
- 突增行为 - 使用量突然大幅增加
- 立即运行审核 - 手动触发一次审核
- 查看审核日志 - 显示最新50条审核记录
- 统计信息 - 总审核次数、封禁数、标记数
curl http://localhost:8045/v1/models \
-H "Authorization: Bearer sk-text"curl http://localhost:8045/v1/chat/completions \
-H "Content-Type: application/json" \
-H "Authorization: Bearer sk-text" \
-d '{
"model": "gemini-2.0-flash-exp",
"messages": [{"role": "user", "content": "你好"}],
"stream": true
}'curl http://localhost:8045/v1/chat/completions \
-H "Content-Type: application/json" \
-H "Authorization: Bearer sk-text" \
-d '{
"model": "gemini-2.0-flash-exp",
"messages": [{"role": "user", "content": "北京天气怎么样"}],
"tools": [{
"type": "function",
"function": {
"name": "get_weather",
"description": "获取天气信息",
"parameters": {
"type": "object",
"properties": {
"location": {"type": "string", "description": "城市名称"}
}
}
}
}]
}'curl http://localhost:8045/v1/chat/completions \
-H "Content-Type: application/json" \
-H "Authorization: Bearer sk-text" \
-d '{
"model": "gemini-2.0-flash-exp",
"messages": [{
"role": "user",
"content": [
{"type": "text", "text": "这张图片里有什么?"},
{
"type": "image_url",
"image_url": {
"url": "..."
}
}
]
}],
"stream": true
}'支持的图片格式:JPEG、PNG、GIF、WebP
.
├── data/ # 数据目录(自动生成)
│ ├── accounts.json # Token 存储
│ ├── users.json # 用户数据
│ ├── share_data.json # 共享系统数据
│ ├── ai_config.json # AI配置
│ └── ai_moderation_logs.json # AI审核日志
├── public/ # 前端页面
│ ├── index.html # 管理后台
│ ├── user.html # 用户中心
│ └── share.html # 共享中心
├── scripts/
│ └── oauth-server.js # OAuth 登录服务
├── src/
│ ├── admin/ # 管理模块
│ │ ├── routes.js # 管理路由
│ │ ├── user_manager.js # 用户管理
│ │ ├── share_manager.js # 共享管理
│ │ ├── ai_moderator.js # AI自动管理
│ │ ├── key_manager.js # 密钥管理
│ │ ├── model_manager.js # 模型管理
│ │ └── ... # 其他管理模块
│ ├── api/
│ │ └── client.js # API 调用逻辑
│ ├── auth/
│ │ └── token_manager.js # Token 管理
│ ├── config/
│ │ └── config.js # 配置加载
│ ├── server/
│ │ └── index.js # 主服务器
│ └── utils/
│ ├── logger.js # 日志模块
│ └── utils.js # 工具函数
├── config.json # 配置文件
└── package.json # 项目配置
- 密码加密存储(PBKDF2)
- 会话Token管理
- API密钥认证
- 频率限制保护
- IP注册限制(每IP每天最多注册数)
- 设备注册限制(基于指纹识别)
- 自动清理长期未登录账号
- 共享使用量监控
- 智能检测异常使用模式
- 自动封禁滥用账号
- 渐进式封禁时长(1天→3天→7天→14天→30天→90天)
- 社区投票机制
{
"server": {
"port": 8045,
"host": "0.0.0.0"
},
"security": {
"apiKey": "sk-text",
"adminPassword": "admin123",
"maxRequestSize": "50mb"
},
"defaults": {
"temperature": 1,
"top_p": 0.85,
"top_k": 50,
"max_tokens": 8096
},
"systemInstruction": "你是一个有帮助的AI助手"
}| 配置项 | 说明 | 默认值 |
|---|---|---|
server.port |
服务端口 | 8045 |
server.host |
监听地址 | 0.0.0.0 |
security.apiKey |
管理员API密钥 | sk-text |
security.adminPassword |
管理后台密码 | admin123 |
security.maxRequestSize |
最大请求体大小 | 50mb |
defaults.temperature |
默认温度参数 | 1 |
defaults.top_p |
默认 top_p | 0.85 |
defaults.top_k |
默认 top_k | 50 |
defaults.max_tokens |
默认最大token数 | 8096 |
systemInstruction |
系统提示词 | - |
# 启动服务
npm start
# 开发模式(自动重启)
npm run dev
# 登录获取 Token
npm run login运行 npm run login 启动OAuth服务器,在浏览器中完成Google登录。
- 访问管理后台的"AI 管理"标签
- 配置API端点(如本地服务地址)
- 设置API密钥
- 调整置信度阈值和检查间隔
- 启用AI审核
- 用户登录用户中心
- 在"我的Token"中添加Google Token
- 勾选"共享此Token"
- Token会出现在共享中心供其他用户使用
系统提供三种方式:
- 自动封禁 - AI检测到异常自动封禁
- 手动封禁 - 在用户管理中手动操作
- 投票封禁 - 社区投票决定是否封禁
采用渐进式封禁:
- 第1次:1天
- 第2次:3天
- 第3次:7天
- 第4次:14天
- 第5次:30天
- 第6次及以后:90天
- 首次使用需要运行
npm run login获取 Token data/目录包含敏感信息,请勿泄露- 建议修改默认的管理员密码
- AI自动管理需要配置有效的AI服务端点
- 共享Token的用户需自行承担配额使用
- 定期查看AI审核日志,确保系统正常运行
MIT License
欢迎提交 Issue 和 Pull Request!
- ✨ 新增完整的Web管理后台
- ✨ 新增用户系统和用户中心
- ✨ 新增Token共享系统
- ✨ 新增AI自动管理功能
- ✨ 新增社区投票封禁机制
- ✨ 新增用户使用统计展示
- 🔧 优化Token轮换机制
- 🔧 完善安全防护措施
- 🎉 初始版本发布
- ✅ OpenAI API兼容
- ✅ 流式响应支持
- ✅ 工具调用支持