nunu-layout-admin/README.md

148 lines
4.1 KiB
Markdown
Raw Normal View History

2025-03-24 05:54:32 +00:00
# N-Admin
N-Admin 是一个基于 [go-nunu](https://github.com/go-nunu/nunu) 开发的开源管理后台模板,采用 **Gin + CasbinRBAC+ Vue3 + AntDesignVue + AntdvPro** 技术栈,提供快速开发的基础架构。
<p align="center"><img src="https://github.com/go-nunu/nunu-layout-admin/blob/main/web/src/assets/images/preview-home.png?raw=true"></p>
<p align="center"><img src="https://github.com/go-nunu/nunu-layout-admin/blob/main/web/src/assets/images/preview-api.png?raw=true"></p>
## 快速开始
```
# 1. clone项目
git clone https://github.com/go-nunu/nunu-layout-admin.git
# 2. 启动项目
cd nunu-layout-admin
go run cmd/server/main.go
# 3. 访问项目
浏览器访问http://localhost:8000
超管账号admin
超管密码123456
普通用户账号user
普通用户密码123456
```
## 📚 角色权限操作流程
当添加API接口或菜单时需要手动添加权限策略。
1. 添加API接口操作路径权限模块->接口管理->添加API
2. 添加前端菜单(操作路径:权限模块->菜单管理->添加菜单)
3. 添加权限策略(操作路径:权限模块->角色管理->添加角色/分配权限)
## 📌 功能特性
- ✅**权限管理**:基于 Casbin 实现 RBAC 角色权限控制,权限粒度支持接口和菜单控制。
- ✅**多数据库支持**:支持 MySQL、Postgres、Sqlite 等数据库。
- ✅**管理员管理**:支持管理员账号增删改查,密码加密存储。
- ✅**JWT 认证**:支持 Token 认证,提供登录、登出功能。
- ✅**前后端分离**RESTful API 设计,支持前后端独立部署。
- ✅**支持一键打包**:整站打包为一个可执行二进制文件。
- ✅**防呆设计**超管账号始终拥有所有菜单及API权限防止误操作。
## 🚀 技术栈
### 后端技术栈
- **[go-nunu](https://github.com/go-nunu/nunu)** - 轻量级 Golang 脚手架
- **[Gin](https://github.com/gin-gonic/gin)** - 轻量级 Web 框架
- **[Casbin](https://github.com/casbin/casbin)** - 权限管理RBAC
- **[GORM](https://github.com/go-gorm/gorm)** - Golang ORM 框架
- **JWT** - 认证和授权
- **MySQL/Postgres/Sqlite** - 数据库支持
### 前端技术栈
- **[AntdvPro](https://github.com/antdv-pro/antdv-pro)** - 企业级中后台前端/设计解决方案
- **[Vue3](https://github.com/vuejs/)** - 渐进式 JavaScript 框架
- **[Vite](https://github.com/vitejs/vite)** - 极速构建工具
## 📦 安装与运行
### 1⃣ 克隆项目
```bash
git clone https://github.com/go-nunu/nunu-layout-admin.git
cd nunu-layout-admin
```
### 2⃣ 后端启动
#### 配置修改
编辑 `config/local.yml` 并修改必要的配置信息。
#### 执行数据迁移,初始化项目数据(仅项目首次启动时执行)
```bash
go run cmd/migration/main.go
```
#### 运行后端服务
```bash
go run cmd/server/main.go
```
或者使用 `nunu run` 进行热加载开发:
```bash
nunu run
```
### 3⃣ 前端启动
```bash
cd web
npm install
npm run dev
```
### 4⃣ 访问地址
后端服务运行在 `http://localhost:8000`
前端服务运行在 `http://localhost:6678`
## 🔑 权限管理RBAC
本项目使用 **Casbin** 进行角色权限管理。
- **角色**:管理员、普通用户等
- **权限**:增删改查等操作权限
- **模型**:采用 `RBAC` 访问控制模型
- **存储**:权限策略存储于数据库
示例策略:
API接口
```
p, admin, api:/api/user, GET
p, admin, api:/api/user, POST
p, admin, api:/api/user, PUT
p, admin, api:/api/user, DELETE
p, user, api:/api/profile, GET
```
前端菜单
```
p, admin, menu:/users, read
p, user, menu:/admin/roles, read
```
## 📦 打包部署
```
cd web
npm run build
cd ../
go build -o server cmd/server/main.go
./server
访问http://127.0.0.1:8000/
```
注意:上面的方法会将服务端和前端的静态资源一起打包到可执行二进制程序中。
如果不需要Golang来渲染前端可以采用Nginx等反向代理工具将前端静态资源部署到Nginx上。
## 📜 许可证
本项目基于 **MIT License** 开源,欢迎贡献!