AI 驱动的智能简历生成器
拖拽编辑、实时 AI 优化、50 套专业模板、多格式导出,轻松打造高质量简历。
扫码加入交流群,获取使用帮助与最新动态:
加入飞书群

--brand-* CSS token,下线全站 60+ 文件硬编码 pink-*localStorage 值自动迁移src/lib/brand-constants.tsh-fullNEXT_PUBLIC_* 构建时变量,改为运行时读取NEXT_PUBLIC_AUTH_ENABLED 改为运行时变量 AUTH_ENABLED| 模板画廊 | 简历编辑器 |
|---|---|
![]() |
![]() |
| AI 填充简历 | AI 图片简历解析 |
|---|---|
![]() |
![]() |
| AI 优化 | AI 语法检查 |
|---|---|
![]() |
![]() |
| 语法一键修复 | JD 匹配分析 |
|---|---|
![]() |
![]() |
| 多格式导出 | 创建分享链接 |
|---|---|
![]() |
![]() |
| 简历分享页 | AI 职业照生成 |
|---|---|
![]() |
![]() |
| 二维码模块 |
|---|
![]() |
| 新建面试 | 模拟面试 |
|---|---|
![]() |
![]() |
| 面试列表 | 面试报告 |
|---|---|
![]() |
![]() |
在 Bilibili 观看完整部署教程:
**加粗** 可显示粗体文字)以下简历模块支持 Markdown 语法:
| 模块 | 支持字段 |
|---|---|
| 个人简介(Summary) | 正文内容 |
| 工作经历 | 描述、亮点(Highlights) |
| 教育背景 | 亮点(Highlights) |
| 项目经历 | 描述、亮点(Highlights) |
| 自定义模块 | 描述 |
| 语言能力 | 描述 |
| GitHub | 描述 |
支持的语法:
**加粗文字** → 粗体
`代码文字` → 行内代码
- 列表项 → 无序列表
技能、证书、个人信息等字段暂不支持 Markdown。
| 层级 | 技术 |
|---|---|
| 框架 | Next.js 16 (App Router, Turbopack) |
| UI | React 19, Tailwind CSS 4, shadcn/ui, Radix UI |
| 拖拽 | @dnd-kit |
| 状态管理 | Zustand |
| 数据库 | Drizzle ORM (SQLite / PostgreSQL) |
| 认证 | NextAuth.js v5 + FingerprintJS |
| AI | Vercel AI SDK v6 + OpenAI / Anthropic |
| Puppeteer Core + @sparticuz/chromium | |
| 国际化 | next-intl |
| 数据校验 | Zod v4 |
# 先生成一个密钥
openssl rand -base64 32
docker run -d -p 3000:3000 \
-e AUTH_SECRET=<你生成的密钥> \
-v jadeai-data:/app/data \
twwch/jadeai:latest
打开 http://localhost:3000。首次启动自动完成数据库迁移和数据初始化。
AUTH_SECRET为必填项,用于会话加密。通过openssl rand -base64 32生成。AI 配置: 无需服务端 AI 环境变量。每位用户在应用内的 设置 > AI 中自行配置 API Key、Base URL 和模型。
使用 PostgreSQL
docker run -d -p 3000:3000 \
-e AUTH_SECRET=<你生成的密钥> \
-e DB_TYPE=postgresql \
-e DATABASE_URL=postgresql://user:pass@host:5432/jadeai \
twwch/jadeai:latest
使用 Google OAuth 登录
docker run -d -p 3000:3000 \
-e AUTH_ENABLED=true \
-e AUTH_SECRET=your-secret \
-e GOOGLE_CLIENT_ID=xxx \
-e GOOGLE_CLIENT_SECRET=xxx \
-v jadeai-data:/app/data \
twwch/jadeai:latest
git clone https://github.com/twwch/JadeAI.git
cd JadeAI
pnpm install
cp .env.example .env.local
编辑 .env.local:
# 数据库(默认 SQLite,无需额外配置)
DB_TYPE=sqlite
# 认证(默认指纹模式,无需额外配置)
AUTH_ENABLED=false
AI 配置: 无需服务端环境变量。每位用户在应用内的 设置 > AI 中自行配置 API Key、Base URL 和模型。
查看 .env.example 了解所有可用选项(Google OAuth、PostgreSQL 等)。
# 生成并执行迁移
pnpm db:generate
pnpm db:migrate
# (可选)填充示例数据
pnpm db:seed
# 启动开发服务器
pnpm dev
| 变量 | 必填 | 默认值 | 说明 |
|---|---|---|---|
AUTH_SECRET |
是 | — | 会话加密密钥 |
DB_TYPE |
否 | sqlite |
数据库类型:sqlite 或 postgresql |
DATABASE_URL |
PostgreSQL 时 | — | PostgreSQL 连接字符串 |
SQLITE_PATH |
否 | ./data/jade.db |
SQLite 数据库文件路径 |
AUTH_ENABLED |
否 | false |
启用 Google OAuth(true)或使用指纹模式(false) |
GOOGLE_CLIENT_ID |
OAuth 时 | — | Google OAuth 客户端 ID |
GOOGLE_CLIENT_SECRET |
OAuth 时 | — | Google OAuth 客户端密钥 |
APP_NAME |
否 | JadeAI |
应用显示名称 |
DEFAULT_LOCALE |
否 | zh |
默认语言:zh 或 en |
| 命令 | 说明 |
|---|---|
pnpm dev |
启动开发服务器(Turbopack) |
pnpm build |
生产构建 |
pnpm start |
启动生产服务器 |
pnpm lint |
运行 ESLint 检查 |
pnpm type-check |
TypeScript 类型检查 |
pnpm db:generate |
生成 Drizzle 迁移文件(SQLite) |
pnpm db:generate:pg |
生成 Drizzle 迁移文件(PostgreSQL) |
pnpm db:migrate |
执行数据库迁移 |
pnpm db:studio |
打开 Drizzle Studio(数据库 GUI) |
pnpm db:seed |
填充示例数据 |
src/
├── app/ # Next.js App Router
│ ├── [locale]/ # 国际化路由 (/zh/..., /en/...)
│ │ ├── dashboard/ # 简历列表与管理
│ │ ├── editor/[id]/ # 简历编辑器
│ │ ├── preview/[id]/ # 全屏预览
│ │ ├── templates/ # 模板画廊
│ │ └── share/[token]/ # 公开分享简历查看
│ └── api/
│ ├── ai/ # AI 接口
│ │ ├── chat/ # 流式对话 + 工具调用
│ │ ├── generate-resume/# AI 生成简历
│ │ ├── jd-analysis/ # JD 匹配分析
│ │ ├── grammar-check/ # 语法与写作检查
│ │ ├── cover-letter/ # 求职信生成
│ │ ├── translate/ # 简历翻译
│ │ └── models/ # 可用 AI 模型列表
│ ├── resume/ # 简历 CRUD、导出、解析、分享
│ ├── share/ # 公开分享访问
│ ├── user/ # 用户信息与设置
│ └── auth/ # NextAuth 认证
├── components/
│ ├── ui/ # shadcn/ui 基础组件
│ ├── editor/ # 编辑器画布、区块、字段、弹窗
│ ├── ai/ # AI 对话面板与气泡
│ ├── preview/templates/ # 50 套简历模板
│ ├── dashboard/ # 仪表盘卡片、网格、弹窗
│ └── layout/ # 头部、主题、语言切换
├── lib/
│ ├── db/ # Schema、仓库、迁移、适配器
│ ├── auth/ # 认证配置
│ └── ai/ # AI 提示词、工具、模型配置
├── hooks/ # 自定义 React Hooks(7 个)
├── stores/ # Zustand 状态仓库(简历、编辑器、设置、UI、引导)
└── types/ # TypeScript 类型定义
JadeAI 内置 50 套专业设计模板,覆盖多种风格和行业需求:
查看全部 50 套模板
| # | 模板 | # | 模板 | # | 模板 |
|---|---|---|---|---|---|
| 1 | Classic | 18 | Clean | 35 | Material |
| 2 | Modern | 19 | Bold | 36 | Medical |
| 3 | Minimal | 20 | Timeline | 37 | Luxe |
| 4 | Professional | 21 | Nordic | 38 | Retro |
| 5 | Two-Column | 22 | Gradient | 39 | Card |
| 6 | ATS | 23 | Magazine | 40 | Rose |
| 7 | Academic | 24 | Corporate | 41 | Teacher |
| 8 | Creative | 25 | Consultant | 42 | Coder |
| 9 | Elegant | 26 | Swiss | 43 | Zigzag |
| 10 | Executive | 27 | Metro | 44 | Neon |
| 11 | Developer | 28 | Architect | 45 | Scientist |
| 12 | Designer | 29 | Japanese | 46 | Blocks |
| 13 | Startup | 30 | Artistic | 47 | Ribbon |
| 14 | Formal | 31 | Sidebar | 48 | Engineer |
| 15 | Infographic | 32 | Finance | 49 | Watercolor |
| 16 | Compact | 33 | Berlin | 50 | Mosaic |
| 17 | Euro | 34 | Legal |
查看全部 API 端点
| 方法 | 端点 | 说明 |
|---|---|---|
GET |
/api/resume |
获取当前用户的简历列表 |
POST |
/api/resume |
创建新简历 |
GET |
/api/resume/[id] |
获取简历详情(含所有模块) |
PUT |
/api/resume/[id] |
更新简历元信息或模块 |
DELETE |
/api/resume/[id] |
删除简历 |
POST |
/api/resume/[id]/duplicate |
复制简历 |
GET |
/api/resume/[id]/export |
导出简历(pdf、docx、html、txt、json) |
POST |
/api/resume/parse |
解析上传的 PDF 或图片简历 |
POST |
/api/resume/[id]/share |
创建分享链接 |
GET |
/api/resume/[id]/share |
获取分享设置 |
DELETE |
/api/resume/[id]/share |
取消分享 |
| 方法 | 端点 | 说明 |
|---|---|---|
GET |
/api/share/[token] |
访问公开分享的简历 |
| 方法 | 端点 | 说明 |
|---|---|---|
POST |
/api/ai/chat |
流式 AI 对话(带简历上下文) |
GET |
/api/ai/chat/sessions |
获取简历的对话会话列表 |
POST |
/api/ai/chat/sessions |
创建新对话会话 |
GET |
/api/ai/chat/sessions/[id] |
获取会话的分页消息 |
DELETE |
/api/ai/chat/sessions/[id] |
删除对话会话 |
POST |
/api/ai/generate-resume |
AI 生成简历 |
POST |
/api/ai/jd-analysis |
JD 匹配分析 |
POST |
/api/ai/grammar-check |
语法与写作检查 |
POST |
/api/ai/cover-letter |
生成求职信 |
POST |
/api/ai/translate |
翻译简历内容 |
GET |
/api/ai/models |
获取可用 AI 模型列表 |
| 方法 | 端点 | 说明 |
|---|---|---|
GET |
/api/user |
获取当前用户信息 |
PUT |
/api/user |
更新用户信息 |
GET |
/api/user/settings |
获取用户设置 |
PUT |
/api/user/settings |
更新用户设置 |
欢迎贡献代码!请按照以下步骤:
git checkout -b feat/your-featuregit commit -m 'feat: add your feature'git push origin feat/your-featureAI 配置是如何工作的?
JadeAI 不需要在服务端配置 AI API 密钥。每位用户在应用内的 设置 > AI 中自行配置 AI 供应商(OpenAI、Anthropic 或自定义端点)、API Key 和模型。API 密钥仅存储在浏览器的 localStorage 中,不会发送到服务端存储。
可以在 SQLite 和 PostgreSQL 之间切换吗?
可以。通过 DB_TYPE 环境变量设置为 sqlite 或 postgresql。SQLite 是默认选项,零配置即可使用。使用 PostgreSQL 时需额外设置 DATABASE_URL。注意:数据不会在两种数据库之间自动迁移。
不使用 OAuth 时认证如何工作?
当 AUTH_ENABLED=false(默认)时,JadeAI 使用 FingerprintJS 进行浏览器指纹识别。系统为每个浏览器生成唯一的指纹 ID 作为用户标识。无需登录界面 — 用户可以直接开始创建简历。
PDF 导出是如何实现的?
PDF 导出使用 Puppeteer Core + @sparticuz/chromium。50 套模板各有独立的服务端导出处理器,将简历渲染为高保真 PDF。同时支持 DOCX、HTML、TXT 和 JSON 格式导出。
$ claude mcp add JadeAI \
-- python -m otcore.mcp_server <graph>