SpringBoot-Shiro-Vue代码规范:项目结构与命名约定详解
2026-02-06 04:46:34作者:平淮齐Percy
SpringBoot-Shiro-Vue
提供一套基于Spring Boot-Shiro-Vue的权限管理思路.前后端都加以控制,做到按钮/接口级别的权限。(当前新版本已移除shiro依赖,简化了配置)
SpringBoot-Shiro-Vue作为一款优秀的权限管理框架,其代码规范与项目结构设计体现了极高的专业水准。本文将为你详细解析这套完整的代码规范体系,帮助你更好地理解和应用这一框架。✨
📁 项目整体架构设计
SpringBoot-Shiro-Vue项目采用前后端分离架构,主要包含两个核心模块:
后端结构:back/ 目录下的Spring Boot应用
前端结构:vue/ 目录下的Vue.js单页应用
后端项目结构规范
后端采用经典的三层架构设计,遵循标准的Maven项目结构:
back/src/main/java/com/heeexy/example/
├── config/ # 配置类目录
├── controller/ # 控制器层
├── dao/ # 数据访问层
├── service/ # 业务逻辑层
├── dto/ # 数据传输对象
└── util/ # 工具类目录
前端项目结构规范
前端采用Vue.js + ElementUI的技术栈,结构清晰:
vue/src/
├── components/ # 公共组件
├── router/ # 路由配置
├── store/ # 状态管理
├── views/ # 页面组件
└── utils/ # 工具函数
🔧 包命名规范详解
基础包名约定
项目采用反向域名命名法,确保唯一性和规范性:
com.heeexy.example
子包分类标准
-
config包:存放所有配置类文件
annotation/- 自定义注解定义exception/- 异常处理相关filter/- 过滤器和切面配置system/- 系统级配置
-
controller包:REST API控制器,按功能模块划分
📝 代码注释规范要求
Java注释标准
项目中所有Java类都遵循统一的注释模板:
/**
* @author: heeexy
* @description: SpringBoot启动类
* @date: 2017/10/24 11:55
*/
注释要素包含:
@author:开发者标识@description:类功能描述@date:创建时间
前端注释规范
Vue组件采用JSDoc风格的注释,清晰说明组件用途和参数。
🎯 权限注解使用规范
权限控制注解
项目采用自定义权限注解替代传统Shiro注解:
@RequiresPermissions("article:add")
命名规则:
- 模块名:操作名
- 如:
user:list、article:delete
🚀 最佳实践建议
1. 分层架构遵循
严格遵循Controller-Service-DAO三层架构,确保代码职责清晰:
- Controller层:LoginController.java
- Service层:LoginService.java
- DAO层:LoginDao.java
2. 异常处理统一
所有异常处理统一在exception/包中管理。
3. 工具类集中管理
所有通用工具方法统一在util/包中实现,避免代码重复。
💡 总结要点
SpringBoot-Shiro-Vue的代码规范体系体现了现代Java开发的优秀实践:
✅ 结构清晰 - 分层明确,职责单一
✅ 命名规范 - 统一标准,易于理解
✅ 注释完整 - 文档齐全,维护方便
✅ 权限精细 - 按钮级别控制,安全可靠
通过遵循这套代码规范,不仅能够提高代码质量,还能显著提升团队协作效率。建议在实际开发中严格遵循这些约定,确保项目的长期可维护性。👍
SpringBoot-Shiro-Vue
提供一套基于Spring Boot-Shiro-Vue的权限管理思路.前后端都加以控制,做到按钮/接口级别的权限。(当前新版本已移除shiro依赖,简化了配置)
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0198- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
603
4.04 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
暂无简介
Dart
847
204
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.46 K
826
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
24
0
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
922
770
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
234
152
昇腾LLM分布式训练框架
Python
130
156