| # 🚀 HAJIMI Gemini API Proxy | |
| 基于某论坛上一位大佬[@Mrjwj34](https://github.com/Moonfanz)基于另一位大佬[@Moonfanzp](https://github.com/Moonfanz)的代码的修改修改而来,由于大佬好长时间没有维护,我自己也遇到些bug,就魔改了一下,求star求star求star | |
| 这是一个基于 FastAPI 构建的 Gemini API 代理,旨在提供一个简单、安全且可配置的方式来访问 Google 的 Gemini 模型。适用于在 Hugging Face Spaces 上部署,并支持openai api格式的工具集成。 | |
| ### 使用文档 | |
| - [【推荐】huggingface的使用文档(手机电脑均可使用)](./wiki/huggingface.md) | |
| - [termux部署的使用文档(手机使用)](./wiki/Termux.md) | |
| - [docker部署的使用文档(服务器自建使用)](./wiki/docker.md) | |
| ### 更新日志 | |
| * v0.1.1 | |
| * 新增联网模式,为所有gemini2.x模型提供联网能力,在模型列表中选择-serach后缀的模型启用 | |
| * 新增环境变量`SERACH_MODE`是否启用联网模式,默认为true | |
| * 新增环境变量`SERACH_PROMPT`为联网模式提示词,默认为`(使用搜索工具联网搜索,需要在content中结合搜索内容)` | |
| * v0.1.0 | |
| * 使用vue重写前端界面,适配移动端 | |
| * 前端界面添加黑夜模式 | |
| * 支持为多模态模型上传图片 | |
| * 可用秘钥数量将异步更新,防止阻塞进程 | |
| * 这次真能北京时间16点自动重置统计数据了 | |
| * 为api秘钥使用统计新增模型使用统计,可分别统计使用不同模型的次数 | |
| * 修改默认api可用次数为100次 | |
| * 降低默认伪装信息长度为5,以减少对上下文的污染 | |
| * v0.0.5beta | |
| * 新增“**伪装信息**功能,默认开启,可在转发消息中添加随机字符串伪装消息,防止被检测 | |
| * 修复若干bug | |
| * 为前端界面新增**功能配置**栏目,可检查功能是否开启 | |
| * 北京时间16点自动重置统计数据 | |
| * 在环境变量中新增`RANDOM_STRING`,是否启用伪装信息,默认值为true | |
| * 在环境变量中新增`RANDOM_STRING_LENGTH`,伪装信息长度,默认为20 | |
| * 为git用户提供单独的`Dockerfile_git` | |
| * 历史版本更新日志请查看[update](./wiki/update.md) | |
| ## ✨ 主要功能: | |
| ### 🔑 API 密钥轮询和管理 | |
| ### 📑 模型列表接口 | |
| ### 💬 聊天补全接口: | |
| * 提供 `/v1/chat/completions` 接口,支持流式(streaming)和非流式响应,与 OpenAI API 格式兼容。 | |
| * 自动将 OpenAI 格式的请求转换为 Gemini 格式。 | |
| ### 🔒 密码保护(可选): | |
| * 通过 `PASSWORD` 环境变量设置密码。 | |
| * 提供默认密码 `"123"`。 | |
| ### 🚦 速率限制和防滥用: | |
| * 通过环境变量自定义限制: | |
| * `MAX_REQUESTS_PER_MINUTE`:每分钟最大请求数(默认 30)。 | |
| * `MAX_REQUESTS_PER_DAY_PER_IP`:每天每个 IP 最大请求数(默认 600)。 | |
| * 超过速率限制时返回 429 错误。 | |
| ### 🧩 服务兼容 | |
| * 提供的接口与 OpenAI API 格式兼容,便于接入各种服务 | |
| ## ⚠️ 注意事项: | |
| * **强烈建议在生产环境中设置 `PASSWORD` 环境变量,并使用强密码。** | |
| * 根据你的使用情况调整速率限制相关的环境变量。 | |
| * 确保你的 Gemini API 密钥具有足够的配额。 | |