ling / readme.md
linchuans's picture
Upload 76 files
3e35e18 verified
# 🚀 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 密钥具有足够的配额。