Skip to content

Latest commit

 

History

History
262 lines (189 loc) · 8.5 KB

File metadata and controls

262 lines (189 loc) · 8.5 KB

Gemini-FastAPI

Python 3.12 FastAPI License

[ English | 中文 ]

将 Gemini 网页端模型封装为兼容 OpenAI API 的 API Server。基于 HanaokaYuzu/Gemini-API 实现。

✅ 无需 API Key,免费通过 API 调用 Gemini 网页端模型!

功能特性

  • 🔐 无需 Google API Key:只需网页 Cookie,即可免费通过 API 调用 Gemini 模型。
  • 🔍 内置 Google 搜索:API 已内置 Gemini 网页端的搜索能力,模型响应更加准确。
  • 💾 会话持久化:基于 LMDB 存储,支持多轮对话历史记录。
  • 🖼️ 多模态支持:可处理文本、图片及文件上传。
  • ⚖️ 多账户负载均衡与自动故障转移:支持多账户分发请求。当当前账户调用失败(如触发风控、Cookie 过期)时,自动切换至其他可用账户重试,确保高可用性。

快速开始

如需 Docker 部署,请参见下方 Docker 部署 部分。

前置条件

  • Python 3.12
  • 拥有网页版 Gemini 访问权限的 Google 账号
  • 从 Gemini 网页获取的 secure_1psidsecure_1psidts Cookie

安装

使用 uv (推荐)

git clone https://github.com/Sagit-chu/Gemini-FastAPI.git
cd Gemini-FastAPI
uv sync

使用 pip

git clone https://github.com/Sagit-chu/Gemini-FastAPI.git
cd Gemini-FastAPI
pip install -e .

配置

编辑 config/config.yaml 并提供至少一组凭证:

gemini:
  clients:
    - id: "client-a"
      secure_1psid: "YOUR_SECURE_1PSID_HERE"
      secure_1psidts: "YOUR_SECURE_1PSIDTS_HERE"
      proxy: null # Optional proxy URL (null/empty keeps direct connection)

Note

详细说明请参见下方 配置 部分。

启动服务

# 使用 uv
uv run python run.py

# 直接用 Python
python run.py

服务默认启动在 http://localhost:8000

Docker 部署

直接运行

docker run -p 8000:8000 \
  -v $(pwd)/data:/app/data \
  -v $(pwd)/cache:/app/cache \
  -e CONFIG_SERVER__API_KEY="your-api-key-here" \
  -e CONFIG_GEMINI__CLIENTS__0__ID="client-a" \
  -e CONFIG_GEMINI__CLIENTS__0__SECURE_1PSID="your-secure-1psid" \
  -e CONFIG_GEMINI__CLIENTS__0__SECURE_1PSIDTS="your-secure-1psidts" \
  -e GEMINI_COOKIE_PATH="/app/cache" \
  ghcr.io/Sagit-chu/gemini-fastapi

Tip

需要代理时可添加 CONFIG_GEMINI__CLIENTS__0__PROXY;省略该变量将保持直连。

GEMINI_COOKIE_PATH 指定容器内保存刷新后 Cookie 的目录。将其挂载(例如 -v $(pwd)/cache:/app/cache)可以在容器重建或重启后保留这些 Cookie,避免频繁重新认证。

使用 Docker Compose

创建 docker-compose.yml 文件:

services:
  gemini-fastapi:
    image: ghcr.io/Sagit-chu/gemini-fastapi:latest
    ports:
      - "8000:8000"
    volumes:
      # - ./config:/app/config  # Uncomment to use a custom config file
      # - ./certs:/app/certs    # Uncomment to enable HTTPS with your certs
      - ./data:/app/data
      - ./cache:/app/cache
    environment:
      - CONFIG_SERVER__HOST=0.0.0.0
      - CONFIG_SERVER__PORT=8000
      - CONFIG_SERVER__API_KEY=${API_KEY}
      - CONFIG_GEMINI__CLIENTS__0__ID=client-a
      - CONFIG_GEMINI__CLIENTS__0__SECURE_1PSID=${SECURE_1PSID}
      - CONFIG_GEMINI__CLIENTS__0__SECURE_1PSIDTS=${SECURE_1PSIDTS}
      - GEMINI_COOKIE_PATH=/app/cache # must match the cache volume mount above
    restart: on-failure:3 # Avoid retrying too many times

然后运行:

docker compose up -d

Important

请务必挂载 /app/data 卷以保证对话数据在容器重启后持久化。 同时挂载 /app/cache(或与 GEMINI_COOKIE_PATH 对应的目录)以保存刷新后的 Cookie,这样在容器重建/重启后无需频繁重新认证。

配置说明

服务器读取 config/config.yaml 配置文件。

各项配置说明请参见 config/config.yaml 文件中的注释。

Gems(model=gem:<id>

你可以在配置文件中定义可复用的预设(gems),并通过把请求里的 model 设置为 gem:<id> 来选择。

当选择 gem 时:

  • 服务端会使用 gem 定义中的 model 作为实际调用的 Gemini 模型名。
  • 对外返回的 OpenAI 兼容响应会尽量回显客户端传入的 model(即 gem:<id>),以保证客户端一致性。
  • 自动同步:服务启动时会自动检查这些 Gem 是否存在于你的 Google 账号中。如果不存在,会自动根据提供的 id(作为标题)和 system_prompt 进行创建。

配置示例:

gemini:
  gems:
    - id: "coding-helper"
      model: "gemini-2.0-flash"
      system_prompt: "You are an expert software engineer."
      tool_policy: "allow" # allow | disallow | auto
      default_temperature: 0.2
      top_p: 0.8
      max_output_tokens: 8192

请求示例(Chat Completions):

{
  "model": "gem:default-gem",
  "messages": [{"role": "user", "content": "你好"}]
}

请求示例(Responses API):

{
  "model": "gem:default-gem",
  "input": "你好"
}

环境变量覆盖

Tip

该功能适用于 Docker 部署和生产环境,可将敏感信息与配置文件分离。

你可以通过带有 CONFIG_ 前缀的环境变量覆盖任意配置项,嵌套键用双下划线(__)分隔,例如:

# 覆盖服务器设置
export CONFIG_SERVER__API_KEY="your-secure-api-key"

# 覆盖 Client 0 的用户凭据
export CONFIG_GEMINI__CLIENTS__0__ID="client-a"
export CONFIG_GEMINI__CLIENTS__0__SECURE_1PSID="your-secure-1psid"
export CONFIG_GEMINI__CLIENTS__0__SECURE_1PSIDTS="your-secure-1psidts"

# 覆盖 Client 0 的代理设置
export CONFIG_GEMINI__CLIENTS__0__PROXY="socks5://127.0.0.1:1080"

# 覆盖对话存储大小限制
export CONFIG_STORAGE__MAX_SIZE=268435456  # 256 MB

客户端 ID 与会话重用

会话在保存时会绑定创建它的客户端 ID。请在配置中保持这些 id 值稳定, 这样在更新 Cookie 列表时依然可以复用旧会话。

Gemini 凭据

Warning

请妥善保管这些凭据,切勿提交到版本控制。这些 Cookie 可访问你的 Google 账号。

使用 Gemini-FastAPI 需提取 Gemini 会话 Cookie:

  1. 在无痕/隐私窗口打开 Gemini 并登录
  2. 打开开发者工具(F12)
  3. 进入 ApplicationStorageCookies
  4. 查找并复制以下值:
    • __Secure-1PSID
    • __Secure-1PSIDTS

Tip

详细操作请参考 HanaokaYuzu/Gemini-API 认证指南

代理设置

每个客户端条目可以配置不同的代理,从而规避速率限制。省略 proxy 字段或将其设置为 null 或空字符串以保持直连。

自定义模型

你可以在 config/config.yaml 中或通过环境变量定义自定义模型。

YAML 配置

gemini:
  model_strategy: "append" # "append" (默认 + 自定义) 或 "overwrite" (仅限自定义)
  models:
    - model_name: "gemini-3.0-pro"
      model_header:
        x-goog-ext-525001261-jspb: '[1,null,null,null,"9d8ca3786ebdfbea",null,null,0,[4],null,null,1]'

环境变量

你可以通过 CONFIG_GEMINI__MODELS 以 JSON 字符串或列表结构的形式提供模型。这为通过 shell 或在自动化环境(例如 Docker)中覆盖设置提供了一种灵活的方式,而无需修改配置文件。

export CONFIG_GEMINI__MODEL_STRATEGY="overwrite"
export CONFIG_GEMINI__MODELS='[{"model_name": "gemini-3.0-pro", "model_header": {"x-goog-ext-525001261-jspb": "[1,null,null,null,\"9d8ca3786ebdfbea\",null,null,0,[4],null,null,1]"}}]'

鸣谢

  • HanaokaYuzu/Gemini-API - 底层 Gemini Web API 客户端
  • zhiyu1998/Gemi2Api-Server - 本项目最初基于此仓库,经过深度重构与工程化改进,现已成为独立项目,并增加了多轮会话复用等新特性。在此表示特别感谢。

免责声明

本项目与 Google 或 OpenAI 无关,仅供学习和研究使用。本项目使用了逆向工程 API,可能不符合 Google 服务条款。使用风险自负。