ai-engineering-init 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/.claude/agents/code-reviewer.md +139 -0
  2. package/.claude/agents/project-manager.md +159 -0
  3. package/.claude/audio/completed.wav +0 -0
  4. package/.claude/commands/add-todo.md +255 -0
  5. package/.claude/commands/check.md +210 -0
  6. package/.claude/commands/crud.md +454 -0
  7. package/.claude/commands/dev.md +503 -0
  8. package/.claude/commands/init-docs.md +681 -0
  9. package/.claude/commands/next.md +251 -0
  10. package/.claude/commands/progress.md +242 -0
  11. package/.claude/commands/start.md +199 -0
  12. package/.claude/commands/sync.md +307 -0
  13. package/.claude/commands/update-status.md +428 -0
  14. package/.claude/docs/Mixin/344/275/277/347/224/250/346/214/207/345/215/227.md +299 -0
  15. package/.claude/docs/README.md +167 -0
  16. package/.claude/docs//345/211/215/347/253/257/345/274/200/345/217/221/346/214/207/345/215/227.md +599 -0
  17. package/.claude/docs//345/220/216/347/253/257/345/274/200/345/217/221/346/214/207/345/215/227.md +726 -0
  18. package/.claude/docs//345/267/245/344/275/234/346/265/201/345/274/200/345/217/221/346/214/207/345/215/227.md +714 -0
  19. package/.claude/docs//345/267/245/345/205/267/347/261/273/344/275/277/347/224/250/346/214/207/345/215/227.md +463 -0
  20. package/.claude/docs//346/225/260/346/215/256/345/272/223/350/256/276/350/256/241/350/247/204/350/214/203.md +390 -0
  21. package/.claude/docs//346/226/260/345/212/237/350/203/275/345/274/200/345/217/221/346/265/201/347/250/213/350/247/204/350/214/203.md +688 -0
  22. package/.claude/docs//346/226/260/351/241/271/347/233/256/345/274/200/345/217/221/346/265/201/347/250/213.md +365 -0
  23. package/.claude/docs//346/241/206/346/236/266/350/257/264/346/230/216.md +393 -0
  24. package/.claude/docs//350/267/257/347/224/261/351/205/215/347/275/256/346/214/207/345/215/227.md +246 -0
  25. package/.claude/framework-config.json +73 -0
  26. package/.claude/hooks/pre-tool-use.js +117 -0
  27. package/.claude/hooks/skill-forced-eval.js +167 -0
  28. package/.claude/hooks/stop.js +58 -0
  29. package/.claude/settings.json +41 -0
  30. package/.claude/skills/add-skill/SKILL.md +352 -0
  31. package/.claude/skills/api-development/SKILL.md +560 -0
  32. package/.claude/skills/architecture-design/SKILL.md +756 -0
  33. package/.claude/skills/backend-annotations/SKILL.md +674 -0
  34. package/.claude/skills/banana-image/CHANGELOG.md +37 -0
  35. package/.claude/skills/banana-image/README.md +146 -0
  36. package/.claude/skills/banana-image/SKILL.md +164 -0
  37. package/.claude/skills/banana-image/assets/logo.png +0 -0
  38. package/.claude/skills/banana-image/references/advanced-usage.md +189 -0
  39. package/.claude/skills/banana-image/scripts/apply_template.py +125 -0
  40. package/.claude/skills/banana-image/scripts/banana_image_exec.ts +412 -0
  41. package/.claude/skills/banana-image/scripts/batch_prep.py +82 -0
  42. package/.claude/skills/banana-image/scripts/package-lock.json +1437 -0
  43. package/.claude/skills/banana-image/scripts/package.json +18 -0
  44. package/.claude/skills/banana-image/scripts/requirements.txt +10 -0
  45. package/.claude/skills/banana-image/templates/poster.json +22 -0
  46. package/.claude/skills/banana-image/templates/product.json +17 -0
  47. package/.claude/skills/banana-image/templates/social.json +22 -0
  48. package/.claude/skills/banana-image/templates/thumbnail.json +17 -0
  49. package/.claude/skills/brainstorm/SKILL.md +648 -0
  50. package/.claude/skills/bug-detective/SKILL.md +1206 -0
  51. package/.claude/skills/code-patterns/SKILL.md +590 -0
  52. package/.claude/skills/collaborating-with-codex/SKILL.md +174 -0
  53. package/.claude/skills/collaborating-with-codex/scripts/codex_bridge.py +275 -0
  54. package/.claude/skills/collaborating-with-gemini/SKILL.md +194 -0
  55. package/.claude/skills/collaborating-with-gemini/scripts/gemini_bridge.py +275 -0
  56. package/.claude/skills/crud-development/SKILL.md +649 -0
  57. package/.claude/skills/data-permission/SKILL.md +599 -0
  58. package/.claude/skills/database-ops/SKILL.md +407 -0
  59. package/.claude/skills/error-handler/SKILL.md +371 -0
  60. package/.claude/skills/file-oss-management/SKILL.md +863 -0
  61. package/.claude/skills/git-workflow/SKILL.md +375 -0
  62. package/.claude/skills/json-serialization/SKILL.md +357 -0
  63. package/.claude/skills/leniu-api-development/SKILL.md +803 -0
  64. package/.claude/skills/leniu-architecture-design/SKILL.md +598 -0
  65. package/.claude/skills/leniu-backend-annotations/SKILL.md +664 -0
  66. package/.claude/skills/leniu-code-patterns/SKILL.md +365 -0
  67. package/.claude/skills/leniu-crud-development/SKILL.md +1110 -0
  68. package/.claude/skills/leniu-data-permission/SKILL.md +256 -0
  69. package/.claude/skills/leniu-database-ops/SKILL.md +426 -0
  70. package/.claude/skills/leniu-error-handler/SKILL.md +462 -0
  71. package/.claude/skills/leniu-java-amount-handling/SKILL.md +461 -0
  72. package/.claude/skills/leniu-java-code-style/SKILL.md +510 -0
  73. package/.claude/skills/leniu-java-concurrent/SKILL.md +400 -0
  74. package/.claude/skills/leniu-java-entity/SKILL.md +751 -0
  75. package/.claude/skills/leniu-java-export/SKILL.md +560 -0
  76. package/.claude/skills/leniu-java-logging/SKILL.md +832 -0
  77. package/.claude/skills/leniu-java-mq/SKILL.md +338 -0
  78. package/.claude/skills/leniu-java-mybatis/SKILL.md +640 -0
  79. package/.claude/skills/leniu-java-report-query-param/SKILL.md +291 -0
  80. package/.claude/skills/leniu-java-task/SKILL.md +367 -0
  81. package/.claude/skills/leniu-java-total-line/SKILL.md +195 -0
  82. package/.claude/skills/leniu-marketing-price-rule-customizer/SKILL.md +301 -0
  83. package/.claude/skills/leniu-marketing-recharge-rule-customizer/SKILL.md +285 -0
  84. package/.claude/skills/leniu-mealtime/SKILL.md +215 -0
  85. package/.claude/skills/leniu-redis-cache/SKILL.md +316 -0
  86. package/.claude/skills/leniu-security-guard/SKILL.md +520 -0
  87. package/.claude/skills/leniu-utils-toolkit/SKILL.md +380 -0
  88. package/.claude/skills/openspec-apply-change/SKILL.md +156 -0
  89. package/.claude/skills/openspec-archive-change/SKILL.md +114 -0
  90. package/.claude/skills/openspec-bulk-archive-change/SKILL.md +246 -0
  91. package/.claude/skills/openspec-continue-change/SKILL.md +118 -0
  92. package/.claude/skills/openspec-explore/SKILL.md +290 -0
  93. package/.claude/skills/openspec-ff-change/SKILL.md +101 -0
  94. package/.claude/skills/openspec-new-change/SKILL.md +74 -0
  95. package/.claude/skills/openspec-onboard/SKILL.md +529 -0
  96. package/.claude/skills/openspec-sync-specs/SKILL.md +138 -0
  97. package/.claude/skills/openspec-verify-change/SKILL.md +168 -0
  98. package/.claude/skills/performance-doctor/SKILL.md +627 -0
  99. package/.claude/skills/project-navigator/SKILL.md +305 -0
  100. package/.claude/skills/redis-cache/SKILL.md +839 -0
  101. package/.claude/skills/scheduled-jobs/SKILL.md +633 -0
  102. package/.claude/skills/security-guard/SKILL.md +748 -0
  103. package/.claude/skills/sms-mail/SKILL.md +766 -0
  104. package/.claude/skills/social-login/SKILL.md +668 -0
  105. package/.claude/skills/store-pc/SKILL.md +366 -0
  106. package/.claude/skills/task-tracker/SKILL.md +307 -0
  107. package/.claude/skills/tech-decision/SKILL.md +393 -0
  108. package/.claude/skills/tenant-management/SKILL.md +603 -0
  109. package/.claude/skills/test-development/SKILL.md +755 -0
  110. package/.claude/skills/ui-pc/SKILL.md +438 -0
  111. package/.claude/skills/utils-toolkit/SKILL.md +615 -0
  112. package/.claude/skills/websocket-sse/SKILL.md +716 -0
  113. package/.claude/skills/workflow-engine/SKILL.md +676 -0
  114. package/.claude/templates//345/276/205/345/212/236/346/270/205/345/215/225/346/250/241/346/235/277.md +56 -0
  115. package/.claude/templates//351/234/200/346/261/202/346/226/207/346/241/243/346/250/241/346/235/277.md +85 -0
  116. package/.claude/templates//351/241/271/347/233/256/347/212/266/346/200/201/346/250/241/346/235/277.md +43 -0
  117. package/.codex/skills/add-skill/SKILL.md +352 -0
  118. package/.codex/skills/add-todo/SKILL.md +269 -0
  119. package/.codex/skills/api-development/SKILL.md +693 -0
  120. package/.codex/skills/architecture-design/SKILL.md +628 -0
  121. package/.codex/skills/backend-annotations/SKILL.md +664 -0
  122. package/.codex/skills/banana-image/CHANGELOG.md +37 -0
  123. package/.codex/skills/banana-image/README.md +146 -0
  124. package/.codex/skills/banana-image/SKILL.md +164 -0
  125. package/.codex/skills/banana-image/assets/logo.png +0 -0
  126. package/.codex/skills/banana-image/references/advanced-usage.md +189 -0
  127. package/.codex/skills/banana-image/scripts/apply_template.py +125 -0
  128. package/.codex/skills/banana-image/scripts/banana_image_exec.ts +412 -0
  129. package/.codex/skills/banana-image/scripts/batch_prep.py +82 -0
  130. package/.codex/skills/banana-image/scripts/package-lock.json +1437 -0
  131. package/.codex/skills/banana-image/scripts/package.json +18 -0
  132. package/.codex/skills/banana-image/scripts/requirements.txt +10 -0
  133. package/.codex/skills/banana-image/templates/poster.json +22 -0
  134. package/.codex/skills/banana-image/templates/product.json +17 -0
  135. package/.codex/skills/banana-image/templates/social.json +22 -0
  136. package/.codex/skills/banana-image/templates/thumbnail.json +17 -0
  137. package/.codex/skills/brainstorm/SKILL.md +648 -0
  138. package/.codex/skills/bug-detective/SKILL.md +1206 -0
  139. package/.codex/skills/check/SKILL.md +367 -0
  140. package/.codex/skills/code-patterns/SKILL.md +442 -0
  141. package/.codex/skills/collaborating-with-codex/SKILL.md +174 -0
  142. package/.codex/skills/collaborating-with-codex/scripts/codex_bridge.py +275 -0
  143. package/.codex/skills/collaborating-with-gemini/SKILL.md +194 -0
  144. package/.codex/skills/collaborating-with-gemini/scripts/gemini_bridge.py +275 -0
  145. package/.codex/skills/crud/SKILL.md +265 -0
  146. package/.codex/skills/crud-development/SKILL.md +637 -0
  147. package/.codex/skills/data-permission/SKILL.md +591 -0
  148. package/.codex/skills/database-ops/SKILL.md +553 -0
  149. package/.codex/skills/dev/SKILL.md +187 -0
  150. package/.codex/skills/error-handler/SKILL.md +361 -0
  151. package/.codex/skills/file-oss-management/SKILL.md +863 -0
  152. package/.codex/skills/git-workflow/SKILL.md +375 -0
  153. package/.codex/skills/init-docs/SKILL.md +194 -0
  154. package/.codex/skills/json-serialization/SKILL.md +357 -0
  155. package/.codex/skills/leniu-api-development/SKILL.md +803 -0
  156. package/.codex/skills/leniu-architecture-design/SKILL.md +594 -0
  157. package/.codex/skills/leniu-backend-annotations/SKILL.md +662 -0
  158. package/.codex/skills/leniu-code-patterns/SKILL.md +365 -0
  159. package/.codex/skills/leniu-crud-development/SKILL.md +1110 -0
  160. package/.codex/skills/leniu-data-permission/SKILL.md +256 -0
  161. package/.codex/skills/leniu-database-ops/SKILL.md +426 -0
  162. package/.codex/skills/leniu-error-handler/SKILL.md +462 -0
  163. package/.codex/skills/leniu-java-amount-handling/SKILL.md +461 -0
  164. package/.codex/skills/leniu-java-code-style/SKILL.md +510 -0
  165. package/.codex/skills/leniu-java-concurrent/SKILL.md +400 -0
  166. package/.codex/skills/leniu-java-entity/SKILL.md +751 -0
  167. package/.codex/skills/leniu-java-export/SKILL.md +560 -0
  168. package/.codex/skills/leniu-java-logging/SKILL.md +832 -0
  169. package/.codex/skills/leniu-java-mq/SKILL.md +338 -0
  170. package/.codex/skills/leniu-java-mybatis/SKILL.md +640 -0
  171. package/.codex/skills/leniu-java-report-query-param/SKILL.md +291 -0
  172. package/.codex/skills/leniu-java-task/SKILL.md +367 -0
  173. package/.codex/skills/leniu-java-total-line/SKILL.md +195 -0
  174. package/.codex/skills/leniu-marketing-price-rule-customizer/SKILL.md +301 -0
  175. package/.codex/skills/leniu-marketing-recharge-rule-customizer/SKILL.md +285 -0
  176. package/.codex/skills/leniu-mealtime/SKILL.md +215 -0
  177. package/.codex/skills/leniu-redis-cache/SKILL.md +316 -0
  178. package/.codex/skills/leniu-security-guard/SKILL.md +520 -0
  179. package/.codex/skills/leniu-utils-toolkit/SKILL.md +378 -0
  180. package/.codex/skills/next/SKILL.md +137 -0
  181. package/.codex/skills/openspec-apply-change/SKILL.md +156 -0
  182. package/.codex/skills/openspec-archive-change/SKILL.md +114 -0
  183. package/.codex/skills/openspec-bulk-archive-change/SKILL.md +246 -0
  184. package/.codex/skills/openspec-continue-change/SKILL.md +118 -0
  185. package/.codex/skills/openspec-explore/SKILL.md +290 -0
  186. package/.codex/skills/openspec-ff-change/SKILL.md +101 -0
  187. package/.codex/skills/openspec-new-change/SKILL.md +74 -0
  188. package/.codex/skills/openspec-onboard/SKILL.md +529 -0
  189. package/.codex/skills/openspec-sync-specs/SKILL.md +138 -0
  190. package/.codex/skills/openspec-verify-change/SKILL.md +168 -0
  191. package/.codex/skills/performance-doctor/SKILL.md +627 -0
  192. package/.codex/skills/progress/SKILL.md +193 -0
  193. package/.codex/skills/project-navigator/SKILL.md +286 -0
  194. package/.codex/skills/redis-cache/SKILL.md +829 -0
  195. package/.codex/skills/scheduled-jobs/SKILL.md +633 -0
  196. package/.codex/skills/security-guard/SKILL.md +739 -0
  197. package/.codex/skills/sms-mail/SKILL.md +766 -0
  198. package/.codex/skills/social-login/SKILL.md +668 -0
  199. package/.codex/skills/start/SKILL.md +154 -0
  200. package/.codex/skills/store-pc/SKILL.md +491 -0
  201. package/.codex/skills/sync/SKILL.md +149 -0
  202. package/.codex/skills/task-tracker/SKILL.md +307 -0
  203. package/.codex/skills/tech-decision/SKILL.md +393 -0
  204. package/.codex/skills/tenant-management/SKILL.md +603 -0
  205. package/.codex/skills/test-development/SKILL.md +755 -0
  206. package/.codex/skills/ui-pc/SKILL.md +475 -0
  207. package/.codex/skills/update-status/SKILL.md +159 -0
  208. package/.codex/skills/utils-toolkit/SKILL.md +593 -0
  209. package/.codex/skills/websocket-sse/SKILL.md +716 -0
  210. package/.codex/skills/workflow-engine/SKILL.md +676 -0
  211. package/.cursor/agents/code-reviewer.md +139 -0
  212. package/.cursor/agents/project-manager.md +159 -0
  213. package/.cursor/commands/opsx-apply.md +152 -0
  214. package/.cursor/commands/opsx-archive.md +157 -0
  215. package/.cursor/commands/opsx-bulk-archive.md +242 -0
  216. package/.cursor/commands/opsx-continue.md +114 -0
  217. package/.cursor/commands/opsx-explore.md +174 -0
  218. package/.cursor/commands/opsx-ff.md +94 -0
  219. package/.cursor/commands/opsx-new.md +69 -0
  220. package/.cursor/commands/opsx-onboard.md +525 -0
  221. package/.cursor/commands/opsx-sync.md +134 -0
  222. package/.cursor/commands/opsx-verify.md +164 -0
  223. package/.cursor/mcp.json +22 -0
  224. package/.cursor/skills/add-skill/SKILL.md +352 -0
  225. package/.cursor/skills/api-development/SKILL.md +560 -0
  226. package/.cursor/skills/architecture-design/SKILL.md +756 -0
  227. package/.cursor/skills/backend-annotations/SKILL.md +674 -0
  228. package/.cursor/skills/banana-image/CHANGELOG.md +37 -0
  229. package/.cursor/skills/banana-image/README.md +146 -0
  230. package/.cursor/skills/banana-image/SKILL.md +164 -0
  231. package/.cursor/skills/banana-image/assets/logo.png +0 -0
  232. package/.cursor/skills/banana-image/references/advanced-usage.md +189 -0
  233. package/.cursor/skills/banana-image/scripts/apply_template.py +125 -0
  234. package/.cursor/skills/banana-image/scripts/banana_image_exec.ts +412 -0
  235. package/.cursor/skills/banana-image/scripts/batch_prep.py +82 -0
  236. package/.cursor/skills/banana-image/scripts/package-lock.json +1437 -0
  237. package/.cursor/skills/banana-image/scripts/package.json +18 -0
  238. package/.cursor/skills/banana-image/scripts/requirements.txt +10 -0
  239. package/.cursor/skills/banana-image/templates/poster.json +22 -0
  240. package/.cursor/skills/banana-image/templates/product.json +17 -0
  241. package/.cursor/skills/banana-image/templates/social.json +22 -0
  242. package/.cursor/skills/banana-image/templates/thumbnail.json +17 -0
  243. package/.cursor/skills/brainstorm/SKILL.md +648 -0
  244. package/.cursor/skills/bug-detective/SKILL.md +1206 -0
  245. package/.cursor/skills/code-patterns/SKILL.md +590 -0
  246. package/.cursor/skills/collaborating-with-codex/SKILL.md +174 -0
  247. package/.cursor/skills/collaborating-with-codex/scripts/codex_bridge.py +275 -0
  248. package/.cursor/skills/collaborating-with-gemini/SKILL.md +194 -0
  249. package/.cursor/skills/collaborating-with-gemini/scripts/gemini_bridge.py +275 -0
  250. package/.cursor/skills/crud-development/SKILL.md +649 -0
  251. package/.cursor/skills/data-permission/SKILL.md +599 -0
  252. package/.cursor/skills/database-ops/SKILL.md +407 -0
  253. package/.cursor/skills/error-handler/SKILL.md +371 -0
  254. package/.cursor/skills/file-oss-management/SKILL.md +863 -0
  255. package/.cursor/skills/git-workflow/SKILL.md +375 -0
  256. package/.cursor/skills/json-serialization/SKILL.md +357 -0
  257. package/.cursor/skills/leniu-api-development/SKILL.md +803 -0
  258. package/.cursor/skills/leniu-architecture-design/SKILL.md +598 -0
  259. package/.cursor/skills/leniu-backend-annotations/SKILL.md +664 -0
  260. package/.cursor/skills/leniu-code-patterns/SKILL.md +365 -0
  261. package/.cursor/skills/leniu-crud-development/SKILL.md +1110 -0
  262. package/.cursor/skills/leniu-data-permission/SKILL.md +256 -0
  263. package/.cursor/skills/leniu-database-ops/SKILL.md +426 -0
  264. package/.cursor/skills/leniu-error-handler/SKILL.md +462 -0
  265. package/.cursor/skills/leniu-java-amount-handling/SKILL.md +461 -0
  266. package/.cursor/skills/leniu-java-code-style/SKILL.md +510 -0
  267. package/.cursor/skills/leniu-java-concurrent/SKILL.md +400 -0
  268. package/.cursor/skills/leniu-java-entity/SKILL.md +751 -0
  269. package/.cursor/skills/leniu-java-export/SKILL.md +560 -0
  270. package/.cursor/skills/leniu-java-logging/SKILL.md +832 -0
  271. package/.cursor/skills/leniu-java-mq/SKILL.md +338 -0
  272. package/.cursor/skills/leniu-java-mybatis/SKILL.md +640 -0
  273. package/.cursor/skills/leniu-java-report-query-param/SKILL.md +291 -0
  274. package/.cursor/skills/leniu-java-task/SKILL.md +367 -0
  275. package/.cursor/skills/leniu-java-total-line/SKILL.md +195 -0
  276. package/.cursor/skills/leniu-marketing-price-rule-customizer/SKILL.md +301 -0
  277. package/.cursor/skills/leniu-marketing-recharge-rule-customizer/SKILL.md +285 -0
  278. package/.cursor/skills/leniu-mealtime/SKILL.md +215 -0
  279. package/.cursor/skills/leniu-redis-cache/SKILL.md +316 -0
  280. package/.cursor/skills/leniu-security-guard/SKILL.md +520 -0
  281. package/.cursor/skills/leniu-utils-toolkit/SKILL.md +380 -0
  282. package/.cursor/skills/openspec-apply-change/SKILL.md +156 -0
  283. package/.cursor/skills/openspec-archive-change/SKILL.md +114 -0
  284. package/.cursor/skills/openspec-bulk-archive-change/SKILL.md +246 -0
  285. package/.cursor/skills/openspec-continue-change/SKILL.md +118 -0
  286. package/.cursor/skills/openspec-explore/SKILL.md +290 -0
  287. package/.cursor/skills/openspec-ff-change/SKILL.md +101 -0
  288. package/.cursor/skills/openspec-new-change/SKILL.md +74 -0
  289. package/.cursor/skills/openspec-onboard/SKILL.md +529 -0
  290. package/.cursor/skills/openspec-sync-specs/SKILL.md +138 -0
  291. package/.cursor/skills/openspec-verify-change/SKILL.md +168 -0
  292. package/.cursor/skills/performance-doctor/SKILL.md +627 -0
  293. package/.cursor/skills/project-navigator/SKILL.md +305 -0
  294. package/.cursor/skills/redis-cache/SKILL.md +839 -0
  295. package/.cursor/skills/scheduled-jobs/SKILL.md +633 -0
  296. package/.cursor/skills/security-guard/SKILL.md +748 -0
  297. package/.cursor/skills/sms-mail/SKILL.md +766 -0
  298. package/.cursor/skills/social-login/SKILL.md +668 -0
  299. package/.cursor/skills/store-pc/SKILL.md +366 -0
  300. package/.cursor/skills/task-tracker/SKILL.md +307 -0
  301. package/.cursor/skills/tech-decision/SKILL.md +393 -0
  302. package/.cursor/skills/tenant-management/SKILL.md +603 -0
  303. package/.cursor/skills/test-development/SKILL.md +755 -0
  304. package/.cursor/skills/ui-pc/SKILL.md +438 -0
  305. package/.cursor/skills/utils-toolkit/SKILL.md +615 -0
  306. package/.cursor/skills/websocket-sse/SKILL.md +716 -0
  307. package/.cursor/skills/workflow-engine/SKILL.md +676 -0
  308. package/AGENTS.md +669 -0
  309. package/CLAUDE.md +205 -0
  310. package/README.md +205 -0
  311. package/bin/index.js +179 -0
  312. package/init.sh +178 -0
  313. package/package.json +27 -0
@@ -0,0 +1,463 @@
1
+ # 工具类使用指南
2
+
3
+ > **重要提示**: 本项目是 RuoYi-Vue-Plus **纯后端项目**,采用**三层架构**。
4
+ > 优先使用项目工具类,禁止重复造轮子。
5
+
6
+ 最后更新: 2026-02-09
7
+
8
+ ---
9
+
10
+ ## 🚨 核心规范
11
+
12
+ ### 禁止事项
13
+
14
+ ```java
15
+ // ❌ 禁止使用 BeanUtils(必须使用 MapstructUtils)
16
+ BeanUtils.copyProperties(source, target); // 禁止!
17
+
18
+ // ❌ 禁止使用 Map 传递业务数据
19
+ public Map<String, Object> getXxx() { ... } // 禁止!必须用 VO
20
+
21
+ // ❌ 禁止使用完整类型引用
22
+ public org.dromara.common.core.domain.R<XxxVo> getXxx() // 禁止!
23
+ // ✅ 正确:先 import,再使用短类名
24
+ import org.dromara.common.core.domain.R;
25
+ public R<XxxVo> getXxx()
26
+ ```
27
+
28
+ ### 工具类优先级
29
+
30
+ ```
31
+ 项目工具类 > Hutool > Apache Commons > 自己实现
32
+ ```
33
+
34
+ ---
35
+
36
+ ## 📋 快速索引
37
+
38
+ | 功能 | 工具类 | 包路径 | 常用方法 |
39
+ |------|--------|--------|---------|
40
+ | **对象转换** | `MapstructUtils` | `o.d.common.core.utils` | `convert()` |
41
+ | 字符串 | `StringUtils` | `o.d.common.core.utils` | `isBlank()`, `format()` |
42
+ | 集合/流 | `StreamUtils` | `o.d.common.core.utils` | `filter()`, `toList()`, `toMap()` |
43
+ | 树结构 | `TreeBuildUtils` | `o.d.common.core.utils` | `build()` |
44
+ | 日期时间 | `DateUtils` | `o.d.common.core.utils` | `getTime()`, `formatDateTime()` |
45
+ | Redis缓存 | `RedisUtils` | `o.d.common.redis.utils` | `setCacheObject()`, `getCacheObject()` |
46
+ | Excel导出 | `ExcelUtil` | `o.d.common.excel.utils` | `exportExcel()` |
47
+ | JSON | `JsonUtils` | `o.d.common.json.utils` | `toJsonString()`, `parseObject()` |
48
+ | 登录用户 | `LoginHelper` | `o.d.common.satoken.utils` | `getUserId()`, `getUsername()` |
49
+ | 业务异常 | `ServiceException` | `o.d.common.core.exception` | `throw new ServiceException()` |
50
+ | Spring容器 | `SpringUtils` | `o.d.common.core.utils` | `getBean()` |
51
+ | Hutool集合 | `CollUtil` | `cn.hutool.core.collection` | `isEmpty()`, `newArrayList()` |
52
+ | Hutool对象 | `ObjectUtil` | `cn.hutool.core.util` | `isNull()`, `isEmpty()` |
53
+ | ID生成 | `IdUtil` | `cn.hutool.core.util` | `getSnowflakeNextId()` |
54
+
55
+ > **包路径说明**: `o.d` = `org.dromara`
56
+
57
+ ---
58
+
59
+ ## 1. 对象转换 - MapstructUtils(必须使用!)
60
+
61
+ > ⚠️ **强制规范**: 禁止使用 `BeanUtils.copyProperties()`,必须使用 `MapstructUtils.convert()`
62
+
63
+ ```java
64
+ import org.dromara.common.core.utils.MapstructUtils;
65
+
66
+ // ✅ 单个对象转换
67
+ XxxVo vo = MapstructUtils.convert(entity, XxxVo.class);
68
+ Xxx entity = MapstructUtils.convert(bo, Xxx.class);
69
+
70
+ // ✅ 集合转换
71
+ List<XxxVo> voList = MapstructUtils.convert(entityList, XxxVo.class);
72
+
73
+ // ❌ 禁止使用 BeanUtils
74
+ // BeanUtils.copyProperties(source, target); // 禁止!
75
+ ```
76
+
77
+ **配合 @AutoMapper 注解**:
78
+
79
+ ```java
80
+ // 在 BO 类上声明映射关系(单数,不是 @AutoMappers)
81
+ @AutoMapper(target = Xxx.class, reverseConvertGenerate = false)
82
+ public class XxxBo extends BaseEntity {
83
+ // ...
84
+ }
85
+
86
+ // 在 VO 类上声明映射关系
87
+ @AutoMapper(target = Xxx.class)
88
+ public class XxxVo implements Serializable {
89
+ // ...
90
+ }
91
+ ```
92
+
93
+ ---
94
+
95
+ ## 2. 字符串操作 - StringUtils
96
+
97
+ ```java
98
+ import org.dromara.common.core.utils.StringUtils;
99
+
100
+ // 判空(推荐)
101
+ StringUtils.isBlank(str); // null / "" / 空白 都返回 true
102
+ StringUtils.isNotBlank(str);
103
+ StringUtils.isEmpty(str); // null / "" 返回 true
104
+ StringUtils.isNotEmpty(str);
105
+
106
+ // 格式化(占位符 {})
107
+ StringUtils.format("用户 {} 不存在", userId);
108
+ // 输出: "用户 123 不存在"
109
+
110
+ // 字符串分割
111
+ List<String> list = StringUtils.splitList("1,2,3"); // ["1", "2", "3"]
112
+ List<Long> ids = StringUtils.splitTo("1,2,3", Convert::toLong); // 转换类型
113
+
114
+ // 驼峰转换
115
+ StringUtils.toCamelCase("user_name"); // "userName"
116
+ StringUtils.toUnderScoreCase("userName"); // "user_name"
117
+ ```
118
+
119
+ ---
120
+
121
+ ## 3. 集合与流操作 - StreamUtils
122
+
123
+ ```java
124
+ import org.dromara.common.core.utils.StreamUtils;
125
+
126
+ // 过滤
127
+ List<User> activeUsers = StreamUtils.filter(users, u -> "1".equals(u.getStatus()));
128
+
129
+ // 提取属性为 List
130
+ List<Long> ids = StreamUtils.toList(users, User::getId);
131
+
132
+ // 提取属性为 Set
133
+ Set<Long> deptIds = StreamUtils.toSet(users, User::getDeptId);
134
+
135
+ // 转为 Map(value 是元素本身)
136
+ Map<Long, User> userMap = StreamUtils.toIdentityMap(users, User::getId);
137
+
138
+ // 转为 Map(自定义 key 和 value)
139
+ Map<Long, String> nameMap = StreamUtils.toMap(users, User::getId, User::getName);
140
+
141
+ // 分组
142
+ Map<Long, List<User>> deptUserMap = StreamUtils.groupByKey(users, User::getDeptId);
143
+
144
+ // 拼接字符串
145
+ String names = StreamUtils.join(users, User::getName); // "张三,李四,王五"
146
+ String names = StreamUtils.join(users, User::getName, "|"); // "张三|李四|王五"
147
+ ```
148
+
149
+ ---
150
+
151
+ ## 4. 树结构构建 - TreeBuildUtils
152
+
153
+ ```java
154
+ import org.dromara.common.core.utils.TreeBuildUtils;
155
+ import cn.hutool.core.lang.tree.Tree;
156
+
157
+ // 构建树(自动检测根节点)
158
+ List<Tree<Long>> tree = TreeBuildUtils.build(list, (node, item) -> {
159
+ node.setId(item.getId());
160
+ node.setParentId(item.getParentId());
161
+ node.setName(item.getName());
162
+ node.setWeight(item.getOrderNum()); // 排序
163
+ // 扩展属性
164
+ node.putExtra("icon", item.getIcon());
165
+ node.putExtra("path", item.getPath());
166
+ });
167
+
168
+ // 指定根节点 ID
169
+ List<Tree<Long>> tree = TreeBuildUtils.build(list, 0L, (node, item) -> {
170
+ // ...
171
+ });
172
+ ```
173
+
174
+ ---
175
+
176
+ ## 5. 日期时间 - DateUtils
177
+
178
+ ```java
179
+ import org.dromara.common.core.utils.DateUtils;
180
+
181
+ // 获取当前时间
182
+ Date now = DateUtils.getNowDate();
183
+ String date = DateUtils.getDate(); // "2026-01-24"
184
+ String time = DateUtils.getTime(); // "2026-01-24 15:30:00"
185
+
186
+ // 格式化
187
+ DateUtils.formatDate(date); // "2026-01-24"
188
+ DateUtils.formatDateTime(date); // "2026-01-24 15:30:00"
189
+
190
+ // 解析
191
+ Date date = DateUtils.parseDate("2026-01-24");
192
+
193
+ // 路径格式
194
+ DateUtils.datePath(); // "2026/01/24"
195
+ ```
196
+
197
+ ---
198
+
199
+ ## 6. Redis 缓存 - RedisUtils
200
+
201
+ ```java
202
+ import org.dromara.common.redis.utils.RedisUtils;
203
+ import java.time.Duration;
204
+
205
+ // 基本操作
206
+ RedisUtils.setCacheObject("key", value); // 永久
207
+ RedisUtils.setCacheObject("key", value, Duration.ofMinutes(30)); // 30分钟过期
208
+ RedisUtils.getCacheObject("key");
209
+ RedisUtils.deleteObject("key");
210
+ RedisUtils.hasKey("key");
211
+
212
+ // List 操作
213
+ RedisUtils.setCacheList("listKey", dataList);
214
+ List<T> list = RedisUtils.getCacheList("listKey");
215
+
216
+ // Map/Hash 操作
217
+ RedisUtils.setCacheMap("mapKey", dataMap);
218
+ RedisUtils.setCacheMapValue("mapKey", "field", value);
219
+ T value = RedisUtils.getCacheMapValue("mapKey", "field");
220
+
221
+ // 原子操作
222
+ RedisUtils.setAtomicValue("counter", 0);
223
+ long val = RedisUtils.incrAtomicValue("counter"); // +1
224
+ long val = RedisUtils.decrAtomicValue("counter"); // -1
225
+ ```
226
+
227
+ ---
228
+
229
+ ## 7. 登录用户 - LoginHelper
230
+
231
+ ```java
232
+ import org.dromara.common.satoken.utils.LoginHelper;
233
+
234
+ // 获取当前登录用户信息
235
+ Long userId = LoginHelper.getUserId();
236
+ String username = LoginHelper.getUsername();
237
+ Long deptId = LoginHelper.getDeptId();
238
+ String tenantId = LoginHelper.getTenantId();
239
+ LoginUser loginUser = LoginHelper.getLoginUser();
240
+
241
+ // 判断登录状态
242
+ boolean isLogin = LoginHelper.isLogin();
243
+
244
+ // 判断是否超级管理员
245
+ boolean isSuperAdmin = LoginHelper.isSuperAdmin();
246
+ ```
247
+
248
+ ---
249
+
250
+ ## 8. 业务异常 - ServiceException
251
+
252
+ ```java
253
+ import org.dromara.common.core.exception.ServiceException;
254
+
255
+ // 抛出业务异常
256
+ throw new ServiceException("用户不存在");
257
+ throw new ServiceException("用户 {} 不存在", userId);
258
+
259
+ // 条件判断
260
+ if (user == null) {
261
+ throw new ServiceException("用户不存在");
262
+ }
263
+ ```
264
+
265
+ ---
266
+
267
+ ## 9. Excel 导出 - ExcelUtil
268
+
269
+ ```java
270
+ import org.dromara.common.excel.utils.ExcelUtil;
271
+
272
+ // Controller 中导出
273
+ @PostMapping("/export")
274
+ public void export(XxxBo bo, HttpServletResponse response) {
275
+ List<XxxVo> list = xxxService.queryList(bo);
276
+ ExcelUtil.exportExcel(list, "数据导出", XxxVo.class, response);
277
+ }
278
+ ```
279
+
280
+ **VO 类 Excel 注解**:
281
+
282
+ ```java
283
+ @Data
284
+ @ExcelIgnoreUnannotated
285
+ public class XxxVo implements Serializable {
286
+
287
+ @ExcelProperty(value = "ID")
288
+ private Long id;
289
+
290
+ @ExcelProperty(value = "名称")
291
+ private String name;
292
+
293
+ @ExcelProperty(value = "状态")
294
+ @ExcelDictFormat(dictType = "sys_normal_disable")
295
+ private String status;
296
+
297
+ @ExcelProperty(value = "创建时间")
298
+ private Date createTime;
299
+ }
300
+ ```
301
+
302
+ ---
303
+
304
+ ## 10. JSON 操作 - JsonUtils
305
+
306
+ ```java
307
+ import org.dromara.common.json.utils.JsonUtils;
308
+
309
+ // 对象转 JSON
310
+ String json = JsonUtils.toJsonString(obj);
311
+
312
+ // JSON 转对象
313
+ User user = JsonUtils.parseObject(json, User.class);
314
+
315
+ // JSON 转 List
316
+ List<User> list = JsonUtils.parseArray(json, User.class);
317
+
318
+ // JSON 转 Map
319
+ Map<String, Object> map = JsonUtils.parseMap(json);
320
+ ```
321
+
322
+ ---
323
+
324
+ ## 11. Hutool 常用工具
325
+
326
+ ```java
327
+ import cn.hutool.core.collection.CollUtil;
328
+ import cn.hutool.core.util.ObjectUtil;
329
+ import cn.hutool.core.util.IdUtil;
330
+
331
+ // 集合判空
332
+ CollUtil.isEmpty(list);
333
+ CollUtil.isNotEmpty(list);
334
+ CollUtil.newArrayList(1, 2, 3);
335
+
336
+ // 对象判空
337
+ ObjectUtil.isNull(obj);
338
+ ObjectUtil.isNotNull(obj);
339
+ ObjectUtil.isEmpty(obj); // null / 空字符串 / 空集合
340
+ ObjectUtil.defaultIfNull(obj, defaultValue);
341
+
342
+ // ID 生成
343
+ long snowflakeId = IdUtil.getSnowflakeNextId(); // 雪花ID(推荐)
344
+ String uuid = IdUtil.simpleUUID(); // 无横线 UUID
345
+ ```
346
+
347
+ ---
348
+
349
+ ## 12. 参数校验 - ValidatorUtils
350
+
351
+ ```java
352
+ import org.dromara.common.core.utils.ValidatorUtils;
353
+ import org.dromara.common.core.validate.AddGroup;
354
+ import org.dromara.common.core.validate.EditGroup;
355
+
356
+ // Controller 层使用 @Validated(推荐)
357
+ @PostMapping
358
+ public R<Void> add(@Validated(AddGroup.class) @RequestBody XxxBo bo) {
359
+ // ...
360
+ }
361
+
362
+ @PutMapping
363
+ public R<Void> edit(@Validated(EditGroup.class) @RequestBody XxxBo bo) {
364
+ // ...
365
+ }
366
+ ```
367
+
368
+ **BO 类校验注解**:
369
+
370
+ ```java
371
+ public class XxxBo extends BaseEntity {
372
+
373
+ @NotNull(message = "ID不能为空", groups = { EditGroup.class })
374
+ private Long id;
375
+
376
+ @NotBlank(message = "名称不能为空", groups = { AddGroup.class, EditGroup.class })
377
+ @Size(max = 100, message = "名称长度不能超过100个字符")
378
+ private String name;
379
+
380
+ @Email(message = "邮箱格式不正确")
381
+ private String email;
382
+ }
383
+ ```
384
+
385
+ ---
386
+
387
+ ## 📊 工具类选择速查
388
+
389
+ | 需求 | 推荐工具 | 说明 |
390
+ |------|---------|------|
391
+ | BO ↔ Entity ↔ VO 转换 | `MapstructUtils.convert()` | **必须使用** |
392
+ | 字符串判空 | `StringUtils.isBlank()` | 推荐项目工具类 |
393
+ | 集合判空 | `CollUtil.isEmpty()` | Hutool |
394
+ | 对象判空 | `ObjectUtil.isNull()` | Hutool |
395
+ | 提取集合属性 | `StreamUtils.toList()` | 项目工具类 |
396
+ | 集合转 Map | `StreamUtils.toIdentityMap()` | 项目工具类 |
397
+ | 分组 | `StreamUtils.groupByKey()` | 项目工具类 |
398
+ | 构建树 | `TreeBuildUtils.build()` | 项目工具类 |
399
+ | 日期格式化 | `DateUtils.formatDateTime()` | 项目工具类 |
400
+ | 抛业务异常 | `throw new ServiceException()` | 项目异常类 |
401
+ | 获取登录用户 | `LoginHelper.getUserId()` | 项目工具类 |
402
+ | Redis 缓存 | `RedisUtils.setCacheObject()` | 项目工具类 |
403
+ | Excel 导出 | `ExcelUtil.exportExcel()` | 项目工具类 |
404
+ | 生成 ID | `IdUtil.getSnowflakeNextId()` | Hutool |
405
+
406
+ ---
407
+
408
+ ## ✅ 在 Service 中的典型用法
409
+
410
+ ```java
411
+ @Service
412
+ @RequiredArgsConstructor
413
+ public class XxxServiceImpl implements IXxxService {
414
+
415
+ private final XxxMapper baseMapper;
416
+
417
+ @Override
418
+ public Boolean insertByBo(XxxBo bo) {
419
+ // 业务校验
420
+ if (isNameExists(bo.getXxxName())) {
421
+ throw new ServiceException("名称已存在");
422
+ }
423
+
424
+ // 对象转换(必须使用 MapstructUtils)
425
+ Xxx entity = MapstructUtils.convert(bo, Xxx.class);
426
+
427
+ return baseMapper.insert(entity) > 0;
428
+ }
429
+
430
+ @Override
431
+ public List<XxxVo> queryList(XxxBo bo) {
432
+ LambdaQueryWrapper<Xxx> lqw = buildQueryWrapper(bo);
433
+ return baseMapper.selectVoList(lqw);
434
+ }
435
+
436
+ private LambdaQueryWrapper<Xxx> buildQueryWrapper(XxxBo bo) {
437
+ LambdaQueryWrapper<Xxx> lqw = Wrappers.lambdaQuery();
438
+ // 字符串判空使用 StringUtils.isNotBlank
439
+ lqw.like(StringUtils.isNotBlank(bo.getXxxName()), Xxx::getXxxName, bo.getXxxName());
440
+ lqw.eq(StringUtils.isNotBlank(bo.getStatus()), Xxx::getStatus, bo.getStatus());
441
+ return lqw;
442
+ }
443
+
444
+ private boolean isNameExists(String name) {
445
+ return baseMapper.exists(Wrappers.<Xxx>lambdaQuery()
446
+ .eq(Xxx::getXxxName, name));
447
+ }
448
+ }
449
+ ```
450
+
451
+ ---
452
+
453
+ ## 🎯 总结
454
+
455
+ **核心原则**:
456
+
457
+ - ✅ **对象转换必须使用 `MapstructUtils.convert()`**(禁止 BeanUtils)
458
+ - ✅ 字符串判空使用 `StringUtils.isBlank()`
459
+ - ✅ 集合操作使用 `StreamUtils`
460
+ - ✅ 树结构使用 `TreeBuildUtils`
461
+ - ✅ 业务异常使用 `ServiceException`
462
+ - ✅ 登录用户使用 `LoginHelper`
463
+ - ✅ 缓存操作使用 `RedisUtils`