告诉 Claude Code 在项目中遵循特定的编程模式/设计模式和技术栈约束

1. 创建 Skill 文件(推荐)

在项目的 .claude/skills/ 目录下创建一个新的 Markdown 文件,例如 tech-stack-guide.md

bash

复制代码
mkdir -p .claude/skills
touch .claude/skills/tech-stack-guide.md

2. 编写 Skill 内容

文件内容分为 YAML 元数据Markdown 正文 ,正文中详细描述技术栈选择、优先级和禁止项。

markdown

复制代码
---
name: tech-stack-guide
description: 定义本项目遵循 Jakarta EE 11 标准的三层架构:Jakarta Faces + JS/CSS(前端)、Jakarta Enterprise Beans(业务逻辑层)、Jakarta Persistence / JDBC(数据持久层)。
triggers:
  - 编程
  - 代码
  - JSF
  - EJB
  - 数据库
  - Jakarta
---

# 项目技术架构规范(Jakarta EE 11)

本项目严格遵循 \*\*Jakarta EE 11\*\* 标准,采用三层架构。每个业务/功能模块都必须包含以下三层,并全部基于 Jakarta EE 11 API。

## 1. 前端展示层(Jakarta Faces + JavaScript/CSS)
- 使用 \*\*Jakarta Faces\*\*(原 JSF)构建用户界面。
- \*\*禁止\*\*使用任何第三方 JSF 组件库(如 PrimeFaces、RichFaces 等)。
- 页面交互使用原生 \*\*JavaScript\*\* 和 \*\*CSS\*\*,不得引入其他前端框架(如 jQuery、React)。
- Jakarta Faces 页面仅使用官方标准命名空间:
  ```xml
  xmlns:h="https://jakarta.ee/xml/ns/jsf/html"
  xmlns:f="https://jakarta.ee/xml/ns/jsf/core"
  xmlns:ui="https://jakarta.ee/xml/ns/jsf/facelets"

- 托管 Bean 使用 @jakarta.inject.Named、@jakarta.faces.view.ViewScoped 等 Jakarta EE 注解。

## 2. 业务逻辑层(Jakarta Enterprise Beans)
- 使用 \*\*EJB\*\*(Session Beans,如 mailto:%60@Stateless`)实现业务逻辑和工作流编排。
- 采用无状态会话 Bean(@jakarta.ejb.Stateless)或有状态会话 Bean(@jakarta.ejb.Stateful)封装业务操作。
- 每个功能模块的业务逻辑必须封装在 EJB 中,不允许在 JSF 托管 Bean 中编写复杂业务逻辑。
- 如需轻量化,可使用 CDI Bean(@jakarta.enterprise.context.ApplicationScoped 等),但须符合 Jakarta EE 11 规范。

## 3. 数据持久层
- 默认使用 Jakarta Persistence(原 JPA)进行对象关系映射,通过 EntityManager 操作数据库。
- 实体类使用 @jakarta.persistence.Entity、@jakarta.persistence.Table 等注解。
- 仅在 JPA 无法满足性能或特殊需求时,才允许使用原生 \*\*JDBC\*\*,且必须在代码注释中明确说明原因。
- 数据库访问统一由 EJB 层调用,前端不直接操作数据库。

## 生成代码时的要求
- 当用户要求实现某个功能时,必须同时生成符合上述三层规范的代码,且全部使用 Jakarta EE 11 API(包名以 jakarta.* 开头)。
- 示例:用户要求"添加用户注册功能",应生成:
  - Jakarta Faces 页面(注册表单,纯标准组件 + 原生 JS/CSS)
  - EJB(`UserService` 或类似,包含注册业务逻辑)
  - JPA 实体(User)和相应的 Repository 或直接使用 EntityManager
- 如果用户未明确指定具体实现细节,默认按此架构生成完整的三层代码。

3. Claude Code 加载该 Skill

  • 创建后,Claude Code 会自动扫描 .claude/skills/ 中的文件。

  • 当你在对话中提出与"编程"、"代码"、"JSF"等触发关键词相关的问题时,该 skill 会被自动激活,Claude Code 将遵循其中的指令。

  • 你也可以手动激活:在对话中输入 /skill tech-stack-guide。


4. 可选:使用项目级指令文件

如果不想用 skill,也可以创建 .claude/instructions.md(如果 Claude Code 支持该文件),写入类似的技术栈约束。但 skill 更灵活,支持触发条件和命名空间隔离。


5. 验证生效

在项目目录下启动 Claude Code,然后尝试提问:

"请帮我生成一个用户登录的 JSF 页面,并实现验证逻辑。"

Claude Code 应会:

  • 生成纯 JSF 页面(无第三方库引用)。

  • 将业务逻辑放入 EJB。

  • 使用 JPA 进行用户验证(如果有数据库交互)。

如果生成的代码违反了规则,你可以进一步补充说明,Claude Code 会记住并调整。

相关推荐
花椰菜菜10 小时前
Anthropic 的最新播客,你需要了解的 Prompt Caching 的一切
aigc·agent·claude
怕浪猫10 小时前
荒岛原始无工业、无电力、无设备,从零搭建最基础计算机体系
人工智能·设计模式·面试
TENSORTEC腾视科技14 小时前
腾视科技重磅推出AI NAS,重塑数据管理方式,开启智能高效新时代
人工智能·ai·七牛云存储·nas·企业存储·ainas·家庭存储
希望永不加班14 小时前
枚举进阶用法:超越常量的设计模式应用
设计模式
求索实验室15 小时前
让AI真正"看见"界面:纯视觉GUI自动化编排器开源了
github·agent
夜雨深秋来15 小时前
多租户 AI Agent 平台架构设计与实践
架构·langchain·agent
东东同学15 小时前
耗时一个月,我把 Nuxt 首屏性能排障经验做成了一个 AI Skill
前端·agent
GoodTimeGGB15 小时前
🚀 2024-2026最新AI热词终极科普:按时间线读懂Agent时代完整进化
agent·mcp·openclaw·harness·hermes
xinxin_091616 小时前
xCodeEval:多语言代码评估基准
ai
summer__777716 小时前
设计模式知识点总结
设计模式