Go to file
chiguyong 47879a11f7 feat: 完整功能补全 - 用户管理/订阅付费/安全限流/管理后台/PDF报告/文档
用户管理增强:
- 邮箱验证(模拟模式)、密码找回、密码修改、个人资料编辑
- 新增 forgot-password/reset-password/verify-email 页面
- Settings 页重构为 Tab 布局

订阅与模拟付费:
- 4个套餐(免费/入门/专业/企业)完整管理
- 模拟支付流程、升级/降级/取消
- 订阅历史记录

安全与限流:
- 接口限流中间件(认证5次/分、全局100次/分)
- 安全响应头(X-Content-Type-Options等)
- 请求日志中间件

管理后台:
- 系统统计(用户数/查询数/引用率/活跃用户)
- 用户管理(列表/搜索/启禁用/修改套餐)
- Admin权限控制

报告增强:
- PDF报告导出(中文支持、封面、统计、表格)
- 报告预览页(统计卡片+最近记录)

项目文档:
- README.md 完整重写
- 后端/前端独立 README

E2E测试: 10/10 全部通过
2026-04-24 10:28:43 +08:00
.qoder/repowiki/zh feat: 完整功能补全 - 用户管理/订阅付费/安全限流/管理后台/PDF报告/文档 2026-04-24 10:28:43 +08:00
backend feat: 完整功能补全 - 用户管理/订阅付费/安全限流/管理后台/PDF报告/文档 2026-04-24 10:28:43 +08:00
docs feat: GEO平台MVP完整实现 2026-04-23 14:46:43 +08:00
frontend feat: 完整功能补全 - 用户管理/订阅付费/安全限流/管理后台/PDF报告/文档 2026-04-24 10:28:43 +08:00
tests feat: GEO平台MVP完整实现 2026-04-23 14:46:43 +08:00
.env.example feat: GEO平台MVP完整实现 2026-04-23 14:46:43 +08:00
.gitignore feat: GEO平台MVP完整实现 2026-04-23 14:46:43 +08:00
README.md feat: 完整功能补全 - 用户管理/订阅付费/安全限流/管理后台/PDF报告/文档 2026-04-24 10:28:43 +08:00
docker-compose.yml feat: GEO平台MVP完整实现 2026-04-23 14:46:43 +08:00

README.md

GEO - AI搜索引擎品牌曝光度优化平台

项目简介

GEOGenerative Engine Optimization是一个SaaS平台帮助品牌监测其在各大AI搜索引擎中的曝光度和引用情况。支持文心一言、Kimi、通义千问、豆包、讯飞星火、天工、清言等主流国内AI平台以及通用搜索引擎。

核心功能

  • 多平台品牌引用监测同时覆盖8个主流AI搜索平台
  • 定时自动查询与即时查询:支持按日/周频率自动执行,也可手动触发
  • 品牌匹配分析:精确匹配、别名匹配、模糊匹配三级策略
  • 竞品引用检测:监测竞争对手在同一查询中的引用情况
  • 数据可视化:引用趋势图、平台对比图等多维度图表
  • CSV/PDF报告导出:一键生成专业数据报告
  • 用户管理与权限控制JWT认证、邮箱验证、密码管理
  • 订阅套餐管理:基于套餐的查询词数量限制
  • 管理后台:系统级用户与数据管理

技术栈

组件 技术
前端 Next.js 14, React 18, TailwindCSS, shadcn/ui, Recharts
后端 Python FastAPI, SQLAlchemy 2.0 (async), Pydantic v2
数据库 PostgreSQL 15, Redis 7
认证 JWT + NextAuth.js
任务调度 APScheduler
浏览器自动化 Playwright
容器化 Docker Compose

快速开始

Docker 方式(推荐)

# 1. 克隆仓库
git clone <repository-url>
cd GEO

# 2. 复制环境变量
cp .env.example .env

# 3. 启动所有服务
docker-compose up -d

# 4. 访问应用
# 前端: http://localhost:3000
# 后端 API: http://localhost:8000
# API 文档: http://localhost:8000/docs

本地开发

后端

cd backend
python3 -m venv venv
source venv/bin/activate  # Windows: venv\Scripts\activate
pip install -r requirements.txt
alembic upgrade head
uvicorn app.main:app --reload --port 8000

前端

cd frontend
npm install
npm run dev

项目结构

GEO/
├── backend/                    # FastAPI 后端服务
│   ├── alembic/                # 数据库迁移脚本
│   ├── app/
│   │   ├── api/                # API 路由层
│   │   │   ├── auth.py         # 认证接口
│   │   │   ├── queries.py      # 查询词管理接口
│   │   │   ├── citations.py    # 引用数据接口
│   │   │   ├── reports.py      # 报告导出接口
│   │   │   └── deps.py         # 依赖注入
│   │   ├── middleware/         # 中间件
│   │   │   ├── rate_limit.py   # 限流中间件
│   │   │   └── logging_middleware.py
│   │   ├── models/             # SQLAlchemy 数据模型
│   │   │   ├── user.py
│   │   │   ├── query.py
│   │   │   ├── citation_record.py
│   │   │   ├── query_task.py
│   │   │   └── subscription.py
│   │   ├── schemas/            # Pydantic 数据校验
│   │   ├── services/           # 业务逻辑层
│   │   ├── workers/            # 任务调度与引擎
│   │   │   ├── scheduler.py    # APScheduler 定时任务
│   │   │   ├── citation_engine.py
│   │   │   └── platforms/      # 各平台适配器
│   │   ├── config.py           # 应用配置
│   │   ├── database.py         # 数据库连接
│   │   └── main.py             # 应用入口
│   ├── requirements.txt
│   └── Dockerfile
├── frontend/                   # Next.js 前端应用
│   ├── app/
│   │   ├── (auth)/             # 认证相关页面
│   │   │   ├── login/
│   │   │   ├── register/
│   │   │   ├── forgot-password/
│   │   │   └── reset-password/
│   │   ├── (dashboard)/        # 仪表盘页面
│   │   │   └── dashboard/
│   │   │       ├── queries/
│   │   │       ├── citations/
│   │   │       ├── reports/
│   │   │       └── settings/
│   │   ├── api/auth/[...nextauth]/
│   │   ├── layout.tsx
│   │   └── page.tsx
│   ├── components/
│   │   ├── ui/                 # shadcn/ui 组件
│   │   ├── charts/             # Recharts 图表组件
│   │   └── layout/             # 布局组件
│   ├── lib/                    # 工具函数与API客户端
│   └── package.json
├── tests/                      # 后端测试
├── docker-compose.yml
├── .env.example
└── README.md

API 概览

模块 路径前缀 说明
认证 /api/v1/auth 注册、登录、密码管理、邮箱验证、用户资料
查询管理 /api/v1/queries 查询词CRUD、立即查询
引用数据 /api/v1/citations 引用记录查询、统计分析
报告导出 /api/v1/reports CSV报告生成与下载

完整的 API 端点列表请参阅 backend/README.md

环境变量

变量名 说明 示例
DATABASE_URL PostgreSQL 连接字符串 postgresql+asyncpg://postgres:postgres123@db:5432/geo_platform
REDIS_URL Redis 连接地址 redis://redis:6379/0
JWT_SECRET JWT 签名密钥 your-secret-key-change-in-production
JWT_EXPIRE_HOURS JWT 过期时间(小时) 24
NEXT_PUBLIC_API_URL 前端调用后端 API 地址 http://localhost:8000
PLAYWRIGHT_BROWSERS_PATH Playwright 浏览器路径 /ms-playwright
ZHIPU_API_KEY 智谱AI API 密钥(可选) -
TONGYI_API_KEY 通义千问 API 密钥(可选) -
CORS_ORIGINS 允许的跨域来源 http://localhost:3000

许可证

MIT