返回顶部
j

java-code-reviewJava代码审查

Java 代码质量保障技能。用于 GitLab 项目分支合并前的 Code Review,支持:(1) 指定项目从 A 分支合并到 B 分支的代码变更审查;(2) 基于 Security/Performance/Correctness/Maintainability/Testing 五大维度进行代码质量检查;(3) 生成 CR 报告并追踪问题修复状态;(4) 用户确认后执行分支合并。触发词:code review、代码审查、合并代码、cr报告、分支合并。

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
98
下载量
免费
免费
0
收藏
概述
安装方式
版本历史

java-code-review

Java Code Review - 代码质量保障

作为 Java 资深专家,保障合并代码的质量。

工作流程

1. 接收任务

用户指定:

  • - 项目名称/ID:GitLab 项目标识
  • 源分支 (A):变更来源分支
  • 目标分支 (B):合并目标分支

2. 获取代码变更

调用 GitLab API 获取差异 commits:

GET /api/v4/projects/{project_id}/repository/compare?from={目标分支}&to={源分支}

获取每个 commit 的 diff:

GET /api/v4/projects/{project_id}/repository/commits/{sha}/diff

3. 执行 Code Review

按以下维度逐项检查:

Review 维度

维度关注点优先级
SecuritySQL注入、XSS、CSRF、认证授权、密钥管理、敏感数据Critical
Performance
N+1查询、内存泄漏、缓存策略、分页、文件流 | High | | Correctness | 边界情况、空值处理、竞态条件、时区处理、错误传播 | High | | Maintainability | 命名规范、单一职责、DRY、复杂度、ORM规范 | Medium | | Testing | 测试覆盖、边界测试、回归测试 | Medium |

Security Checklist

  • - [ ] SQL Injection — 所有查询使用参数化语句或ORM;无用户输入字符串拼接
  • [ ] XSS — 用户内容在渲染前已转义/净化
  • [ ] CSRF Protection — 状态变更请求需要有效CSRF令牌
  • [ ] Authentication — 每个受保护端点在处理前验证用户身份
  • [ ] Authorization — 资源访问限定在请求用户权限范围内;无IDOR漏洞
  • [ ] Input Validation — 所有外部输入在服务端验证类型、长度、格式和范围
  • [ ] Secrets Management — 源码中无API密钥、密码、令牌或凭证;秘密来自环境变量或vault
  • [ ] Dependency Safety — 新依赖来自可信来源,积极维护,无已知CVE
  • [ ] Sensitive Data — PII、令牌和秘密不记录日志、不包含在错误消息中、不在API响应中返回
  • [ ] Rate Limiting — 公共和认证端点有速率限制
  • [ ] File Upload Safety — 上传文件验证类型和大小,存储在webroot外
  • [ ] HTTP Security Headers — 设置CSP、X-Content-Type-Options、HSTS

Performance Checklist

  • - [ ] N+1 Queries — 数据库访问模式已批量或联接;无循环单独查询
  • [ ] Memory Leaks — 事件监听器、订阅、定时器在卸载/销毁时清理
  • [ ] Caching Strategy — 昂贵计算和API响应使用适当缓存
  • [ ] Database Indexing — 查询在索引列上过滤/排序;新查询已用EXPLAIN检查
  • [ ] Pagination — 列表端点和查询使用分页;无无界SELECT *
  • [ ] Async Operations — 长时间运行任务卸载到后台作业或队列
  • [ ] 严禁处理文件流 — 不允许在该系统中处理文件流,会影响整体服务的稳定性

Correctness Checklist

  • - [ ] Edge Cases — 空数组、空字符串、零值、负数和最大值已处理
  • [ ] Null/Undefined Handling — 可空值在访问前已检查
  • [ ] Race Conditions — 共享状态的并发访问使用锁、事务或原子操作
  • [ ] Timezone Handling — 日期以UTC存储;显示转换在表示层进行
  • [ ] Error Propagation — 异步调用和外部服务的错误已捕获和处理
  • [ ] State Consistency — 多步骤变更是事务性的;部分失败使系统处于有效状态

Maintainability Checklist

  • - [ ] Naming Clarity — 变量、函数和类有描述性名称
  • [ ] Single Responsibility — 每个函数/类/模块做一件事
  • [ ] DRY — 重复逻辑提取到共享工具;复制粘贴块已合并
  • [ ] Cyclomatic Complexity — 函数分支复杂度低;深度嵌套链已重构
  • [ ] Dead Code Removal — 注释掉的代码、未使用的导入、不可达分支已删除
  • [ ] Magic Numbers & Strings — 字面值提取到命名常量
  • [ ] ORM Operation — ORM代码只允许在mapper层操作,包括mybatis plus的调用也只能在mapper层,其他包下不允许引用mybatis
  • [ ] Commented Code — 任何地方不允许将原有代码注释掉提交,只能删除
  • [ ] SQL Business Logic — sql里面不要带业务逻辑,包括魔数、固定值等,需由业务层传参进来
  • [ ] 包命名规范 — 包名需要以 cn.ctg.travel.{项目名} 为前缀

Testing Checklist

  • - [ ] Test Coverage — 新逻辑路径有对应测试
  • [ ] Edge Case Tests — 测试覆盖边界值、空输入、null和错误条件
  • [ ] No Flaky Tests — 测试是确定性的
  • [ ] Meaningful Assertions — 测试断言行为和结果,而非实现细节
  • [ ] Regression Tests — Bug修复包含重现原始bug的测试

4. 生成 CR 报告

报告格式:

markdown

CR Report - {项目名}

变更概述

  • - 源分支:{A}
  • 目标分支:{B}
  • Commits 数量:{N}
  • 涉及文件数:{M}
  • Commit Authors:{作者列表}

问题清单

Critical (必须修复)
序号问题描述文件:行号Author建议修复方案
1............

High (强烈建议)

...

Medium (建议优化)

...

Low (可选优化)

...

通过项

  • - [x] Security - 无安全漏洞
  • [x] Performance - 性能可接受
...

总结与建议

...

合并建议

  • - [ ] 建议合并(无 Critical/High 问题)
  • [ ] 修复后合并(存在 Critical/High 问题需修复)
  • [ ] 不建议合并(存在严重问题)

5. 用户确认与合并

询问用户是否执行合并:

CR 报告已生成。是否执行分支合并?

  • - 确认合并:将 {源分支} 合并到 {目标分支}
  • 取消:不执行合并

用户确认后,执行合并 API:

POST /api/v4/projects/{projectid}/mergerequests
{
source_branch: {源分支},
target_branch: {目标分支},
title: Merge {源分支} into {目标分支}
}

或直接合并:

POST /api/v4/projects/{project_id}/repository/commits
{
branch: {目标分支},
commit_message: Merge branch {源分支},
actions: []
}

GitLab 配置

默认配置(可通过用户指定覆盖):

配置项
GitLab 地址https://git.xxx.com
认证方式
PRIVATE-TOKEN 或 Authorization: Bearer |
| Token 来源 | TOOLS.md 或用户指定 |

使用示例

示例 1:指定项目分支合并

用户:帮我 review openapi 项目,从 release-20260324 合并到 test 分支

执行步骤:

  1. 1. 获取 compare:from=test&to=release/release-20260324
  2. 获取差异 commits 和 diffs
  3. 执行 CR 检查
  4. 生成报告
  5. 询问是否合并

示例 2:查看特定 commit 变更

用户:帮我检查 ctg-travel-order 项目的 commit abc123

执行步骤:

  1. 1. 获取该 commit 的 diff
  2. 执行 CR 检查
  3. 生成单 commit 报告

注意事项

  1. 1. 安全优先:Critical 问题必须修复才能合并
  2. 责任追溯:每个问题都关联 Commit Author
  3. 追踪闭环:记录问题并在后续 CR 中检查修复状态
  4. 报告存档:CR 报告保存到 task/codereview/{日期}/ 目录

相关文件

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 java-code-review-1776025175 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 java-code-review-1776025175 技能

通过命令行安装

skillhub install java-code-review-1776025175

下载

⬇ 下载 java-code-review v1.0.0(免费)

文件大小: 9.2 KB | 发布时间: 2026-4-13 10:42

v1.0.0 最新 2026-4-13 10:42
Initial release of Java code review skill for GitLab projects:

- Supports branch code review before merging, with selectable source and target branches.
- Evaluates changes on five dimensions: Security, Performance, Correctness, Maintainability, and Testing.
- Generates structured Code Review (CR) reports, tracking issues and fix status by commit author.
- Provides merge decision support and can execute branch merges on user confirmation.
- Includes detailed security and quality checklists tailored to Java projects.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部