OpenSpec 中文版规范助手 - 规范驱动的 AI 编程开发,帮助初始化、创建提案、编写规格、校验格式并归档变更。触发条件: 当用户提及 openspec、规范文档、需求管理、变更提案、spec-driven development 等关键词时主动调用。
/plugin marketplace add ruan-cat/monorepo/plugin install common-tools@ruan-cat-toolsThis skill inherits all available tools. When active, it can use any tool Claude has access to.
OpenSpec 是一个 CLI 工具,通过规范驱动的开发流程帮助开发者与 AI 编码助手建立明确的需求共识。核心理念是:在编写代码前,先将需求文档化并达成一致,从而消除 AI 工具仅依赖对话历史产生的不可预测输出。
✅ 最适合:
❌ 不适合:
前期多花 10-15 分钟与 AI 澄清需求、编写规范,能节省数小时的返工时间。规范文档会随着项目演进不断积累,最终形成完整的系统文档。
OpenSpec 使用独特的双文件夹模型,将"事实"与"提案"分离:
openspec/
├── specs/ # 📚 事实:已实施并归档的规范(source-of-truth)
│ ├── auth.md
│ ├── api.md
│ └── database.md
└── changes/ # 💡 提案:待实施的变更(明确的差异管理)
├── add-oauth-login/
│ ├── proposal.md
│ ├── tasks.md
│ └── specs/
│ └── auth-delta.md
└── optimize-api-cache/
├── proposal.md
└── specs/
└── api-delta.md
设计理念:
specs/ 是系统的当前状态changes/ 是即将到来的变化全局安装(推荐):
npm install -g @org-hex/openspec-chinese@latest
# 或使用 pnpm
pnpm install -g @org-hex/openspec-chinese@latest
临时使用(不安装):
pnpm dlx @org-hex/openspec-chinese init
pnpm dlx @org-hex/openspec-chinese proposal "功能描述"
验证安装:
openspec-chinese --version
openspec-chinese --help
OpenSpec 支持 20+ AI 编程助手,包括:
无需额外配置,安装后即可在所有支持的工具中使用。
# 在全新项目中初始化
openspec-chinese init
# 在现有 OpenSpec 项目中切换到中文版
openspec-chinese update
生成的完整结构:
openspec/
├── project.md # 项目上下文(技术栈、架构、团队约定)
├── AGENTS.md # AI 助手通用指令(20+ 工具兼容)
├── specs/ # 现行规范库(已归档的事实)
├── changes/ # 变更提案目录
└── templates/ # 自定义模板(可选)
重要:初始化后如果 IDE 里斜杠命令未出现,请重启 IDE/AI 工具。
生成 project.md 后,应立即向 AI 提出:
请阅读 openspec/project.md 并帮助我填写:
1. 项目的核心技术栈
2. 架构设计约定
3. 编码规范和最佳实践
4. 团队协作流程
完善的 project.md 能让 AI 助手更好地理解项目上下文,生成更符合实际的规范文档。
目标:创建变更文件夹,初步定义需求
# 命令行方式
openspec-chinese proposal "添加 OAuth 登录功能"
# AI 工具斜杠命令
/openspec-proposal
输出:
openspec/changes/add-oauth-login/
├── proposal.md # AI 生成的初步提案
├── tasks.md # 任务分解清单
└── specs/ # 增量规范(空)
交互要点:
proposal.md 和 tasks.md目标:人和 AI 共同审查,反复迭代直到需求明确
# 查看提案详情
openspec-chinese show add-oauth-login
# 在 AI 工具中交互
"请根据我的反馈修改 proposal.md:
1. 只支持 GitHub 和 Google OAuth
2. 需要处理现有用户的账号合并逻辑
3. 增加 OAuth 失败时的降级方案"
迭代过程:
proposal.md 的 Why/What/Impacttasks.md 的任务拆解是否合理关键:这个阶段多花时间,后续实施会快很多。
目标:在 specs/ 目录下编写符合格式的增量规范
# AI 工具中请求
"请为 add-oauth-login 变更编写规格文档,放在 specs/ 目录"
规范格式(详见下文"规格文档格式要求"):
## ADDED Requirements
### Requirement: OAuth 登录支持
系统 MUST 支持通过 GitHub 和 Google 进行 OAuth 登录。
#### Scenario: GitHub OAuth 登录成功
- **WHEN** 用户点击"使用 GitHub 登录"按钮
- **THEN** 系统跳转到 GitHub OAuth 授权页面
- **AND** 授权成功后返回并创建会话
校验格式:
# 严格格式校验
openspec-chinese validate add-oauth-login --strict
# 中文格式专项校验(需配置)
npm run validate:chinese
实施开发:
# AI 工具中参考规范实施
"请参考 openspec/changes/add-oauth-login/specs/ 中的规范,
按照 tasks.md 的任务清单逐步实施功能"
任务追踪:
tasks.md 中勾选已完成的任务目标:将完成的变更合并到主规范库
# 查看所有变更
openspec-chinese list
# 归档已完成的变更
openspec-chinese archive add-oauth-login --yes
效果:
changes/add-oauth-login/ 的规范合并到 specs/flowchart TD
A[1. 起草提案<br/>AI 澄清问题] --> B[2. 审查对齐<br/>迭代完善需求]
B --> C[3. 编写规格<br/>Delta + Scenarios]
C --> D[4. 校验格式<br/>validate --strict]
D --> E{格式正确?}
E -- 否 --> C
E -- 是 --> F[5. 实施开发<br/>按规范编码]
F --> G[6. 归档文档<br/>archive --yes]
G --> H[规范库更新<br/>活文档形成]
OpenSpec 使用严格的格式规范,确保 AI 和人都能准确理解需求。
三种变更类型:
## ADDED Requirements
# 新增的能力
## MODIFIED Requirements
# 修改现有行为
## REMOVED Requirements
# 废弃的功能(需说明原因和迁移路径)
格式:
### Requirement: [需求名称]
系统 [MUST/SHALL/SHOULD] [能力描述]。
强制关键词:
示例:
### Requirement: 用户搜索功能
系统 MUST 提供用户搜索功能,支持按用户名、邮箱、手机号进行模糊查询。
系统 SHOULD 在搜索结果中高亮匹配的关键词。
格式:
#### Scenario: [场景名称]
- **WHEN** [前置条件]
- **THEN** [预期结果]
- **AND** [额外条件/结果]
要求:
示例:
#### Scenario: 按邮箱搜索用户
- **WHEN** 用户在搜索框输入 "test@example.com"
- **THEN** 系统返回邮箱包含该字符串的用户列表
- **AND** 列表按相关度排序
- **AND** 邮箱中的匹配部分高亮显示
#### Scenario: 搜索无结果
- **WHEN** 用户输入不存在的邮箱
- **THEN** 系统显示"未找到匹配用户"
- **AND** 提示用户检查输入或尝试其他搜索条件
删除需求时必须提供 Reason 和 Migration:
## REMOVED Requirements
### Requirement: 用户密码明文存储
- **Reason**: 严重的安全隐患,违反 OWASP 安全规范
- **Migration**:
1. 所有密码已迁移到 bcrypt 加密存储
2. 用户首次登录时会自动升级密码加密方式
3. 详细迁移指南:`docs/password-migration.md`
修改现有功能时应说明变化:
## MODIFIED Requirements
### Requirement: 用户列表分页
- **变化说明**: 将每页默认显示数量从 20 条调整为 50 条
- **原因**: 用户反馈每页 20 条过少,频繁翻页影响体验
- **影响范围**:
- 前端分页组件
- 后端 API 默认参数
- 性能测试基准需重新评估
#### Scenario: 默认分页数量
- **WHEN** 用户访问用户列表页面
- **THEN** 系统默认每页显示 50 条记录
- **AND** 用户可以在设置中自定义每页条数(10/20/50/100)
## ADDED Requirements
### Requirement: 用户数据导出功能
系统 MUST 提供用户数据导出功能,支持 CSV 和 JSON 两种格式。
#### Scenario: 导出为 CSV 格式
- **WHEN** 管理员点击"导出为 CSV"按钮
- **THEN** 系统生成包含所有用户数据的 CSV 文件
- **AND** 文件包含字段:用户名、邮箱、注册时间、最后登录时间、状态
- **AND** 文件名格式为 `users_export_YYYYMMDD_HHmmss.csv`
#### Scenario: 导出权限检查
- **WHEN** 非管理员用户尝试导出
- **THEN** 系统返回 403 Forbidden 错误
- **AND** 前端显示"权限不足"提示
#### Scenario: 大数据量导出
- **GIVEN** 系统有超过 10000 条用户记录
- **WHEN** 管理员点击导出
- **THEN** 系统显示"正在生成导出文件"进度提示
- **AND** 导出任务在后台异步执行
- **AND** 完成后通过邮件发送下载链接
## MODIFIED Requirements
### Requirement: 用户列表查询性能
- **变化说明**: 为用户表添加邮箱和手机号索引
- **原因**: 当前搜索性能在 10 万用户以上明显下降
- **预期效果**: 搜索响应时间从 2-3 秒降低到 < 500ms
## REMOVED Requirements
### Requirement: 用户密码明文存储
- **Reason**: 严重安全隐患,必须移除
- **Migration**:
1. 所有密码已迁移到 bcrypt 加密(cost=10)
2. 用户下次登录时自动完成迁移
3. 详细文档:`docs/security/password-migration.md`
# 初始化全新项目
openspec-chinese init
# 更新/切换到中文版
openspec-chinese update
# 查看版本
openspec-chinese --version
# 创建新提案
openspec-chinese proposal "功能描述"
# 查看所有变更
openspec-chinese list
# 查看特定变更详情
openspec-chinese show <change-name>
# 校验格式(严格模式)
openspec-chinese validate <change-name> --strict
# 归档已完成的变更
openspec-chinese archive <change-name> --yes
在支持的 AI 工具(Claude Code, Cursor 等)中:
/openspec-proposal # 创建新提案
/openspec-validate # 校验当前变更
/openspec-archive # 归档变更
在 openspec/templates/ 目录下创建自定义模板:
# 创建功能规格模板
openspec/templates/feature-spec.md
# 创建 API 规格模板
openspec/templates/api-spec.md
# 创建数据库变更模板
openspec/templates/db-migration-spec.md
<!-- openspec/templates/feature-spec.md -->
## ADDED Requirements
### Requirement: [功能名称]
系统 MUST [功能描述]。
#### Scenario: [主要场景]
- **WHEN** [前置条件]
- **THEN** [预期结果]
- **AND** [额外条件]
#### Scenario: [错误场景]
- **WHEN** [异常情况]
- **THEN** [错误处理]
- **AND** [用户提示]
## MODIFIED Requirements
(如有修改现有功能,在此说明)
## REMOVED Requirements
(如有废弃功能,在此说明原因和迁移路径)
# 创建新变更时,从模板复制
cp openspec/templates/feature-spec.md openspec/changes/new-feature/specs/feature.md
# 然后填充具体内容
# 每次编辑规格后立即校验
openspec-chinese validate <change> --strict
# 配置 Git pre-commit hook
npm run validate:chinese
<!-- openspec/project.md -->
# 项目上下文
## 技术栈
- 前端: React 18 + TypeScript
- 后端: Node.js + Express
- 数据库: PostgreSQL 14
## 架构约定
- RESTful API 设计
- JWT 认证
- 统一错误处理中间件
## 编码规范
- ESLint + Prettier
- 函数式组件优先
- 使用 React Query 管理服务端状态
完善的 project.md 能让 AI 生成更符合项目规范的代码。
OpenSpec 中文版与英文版完全兼容:
# 切换到中文版
openspec-chinese update
# 切换回英文版
openspec update
两个版本可以在团队中并存,规范文件格式完全一致。
症状:openspec-chinese: command not found
解决方案:
# 检查是否在 PATH 中
which openspec-chinese # Mac/Linux
where openspec-chinese # Windows
# 检查 npm 全局 bin 路径
npm config get prefix
# 重新安装
npm uninstall -g @org-hex/openspec-chinese
npm install -g @org-hex/openspec-chinese@latest
症状:AI 工具中看不到 /openspec-* 命令
解决方案:
# 执行更新命令
openspec-chinese update
# 重启 IDE/AI 工具
# 检查是否生成了 AGENTS.md
ls openspec/AGENTS.md
常见错误:
缺少 Delta 分区
Error: Missing required Delta sections (ADDED/MODIFIED/REMOVED)
解决:确保至少有一个 Delta 分区
缺少 MUST/SHALL 关键词
Error: Requirement missing mandatory keywords
解决:在需求描述中添加 MUST/SHALL/SHOULD
Scenario 层级错误
Error: Scenario must be under a Requirement
解决:确保 #### Scenario: 在 ### Requirement: 之下
Gherkin 关键字使用中文
Error: Gherkin keywords must be in English
解决:使用 WHEN/THEN/AND 而非"当/那么/并且"
症状:openspec-chinese archive 报错
可能原因:
解决方案:
# 先校验格式
openspec-chinese validate <change> --strict
# 检查 specs/ 目录
ls openspec/changes/<change>/specs/
# 解决 Git 冲突后重试
git status
本技能应在以下场景主动调用:
必须要及时更新对应任务的
tasks.md任务进度文件。避免出现大批量完成任务后,没有更新进度文件的情况,带来严重的误解。
务必要启动多个在后台运行的子代理,同时完成 openspec 设定的一系列繁杂的任务。以便加快速度。你应该至少同时启用至少 4 个子代理。并根据情况,主动增加足够数量的子代理完成任务。
务必用中文回复用户。
为了避免你在自动合并上下文的时候,给后续的任务带来明显的幻觉,你应该及时的重新阅读 openspec 的任务规范要求。
tasks.md 所记录的全部任务。你应该同时新建多个子代理,做出合理的任务划分,一次性完成任务。主代理的职责: 主代理应该负责全面的,完整的阅读来自 openspec 目录下全部的 markdown 文档任务要求。并按照模块和错误类型,新建足够数量的子代理。并持续监听,定期收集来自子代理的处理反馈。子代理的职责: 子代理应该严格按照主代理给定的要求来完成任务。validate --strictproject.md 提供项目上下文changes/ 目录中的提案可作为 PR 描述specs/ 成为团队共识