diff --git a/.editorconfig b/.editorconfig
deleted file mode 100644
index fd230fd6..00000000
--- a/.editorconfig
+++ /dev/null
@@ -1,35 +0,0 @@
-# EditorConfig is awesome: https://EditorConfig.org
-
-# top-most EditorConfig file
-root = true
-
-# Unix-style newlines with a newline ending every file
-[*]
-charset = utf-8
-end_of_line = lf
-insert_final_newline = true
-trim_trailing_whitespace = true
-
-# Java files
-[*.java]
-indent_style = space
-indent_size = 4
-
-# XML files
-[*.xml]
-indent_style = space
-indent_size = 4
-
-# YAML files
-[*.{yml,yaml}]
-indent_style = space
-indent_size = 2
-
-# Properties files
-[*.properties]
-indent_style = space
-indent_size = 4
-
-# Markdown files
-[*.md]
-trim_trailing_whitespace = false
diff --git a/.gitattributes b/.gitattributes
deleted file mode 100644
index a3fd9cca..00000000
--- a/.gitattributes
+++ /dev/null
@@ -1,14 +0,0 @@
-# Auto detect text files and perform LF normalization
-* text=auto eol=lf
-
-# Java files
-*.java text eol=lf
-*.xml text eol=lf
-
-# Config files
-*.yml text eol=lf
-*.yaml text eol=lf
-*.properties text eol=lf
-
-# Shell scripts
-*.sh text eol=lf
diff --git a/README.md b/README.md
index 5b140fb4..06fef97f 100644
--- a/README.md
+++ b/README.md
@@ -6,18 +6,23 @@
**Spring Boot 4 企业级权限管理系统后端**
-[](https://spring.io/projects/spring-boot)
+[](https://spring.io/projects/spring-boot)
[](https://openjdk.org/)
[](LICENSE)
-
-[](https://www.youlai.tech/docs/admin/backend/java/)
-[](https://vue.youlai.tech)
[](https://gitee.com/youlaiorg/youlai-boot/stargazers)
[](https://github.com/youlaitech/youlai-boot)
[](https://gitcode.com/youlai/youlai-boot/stargazers)
+
+
+
+
+[🖥️ 在线预览](https://vue.youlai.tech) | [📲 移动端预览](https://app.youlai.tech) | [📖 文档](https://www.youlai.tech/docs/admin/backend/java/)
+
+
+
## 简介
**youlai-boot** 是一套基于 Spring Boot 4 的企业级权限管理系统后端,配套前端 [vue3-element-admin](https://gitee.com/youlaiorg/vue3-element-admin) 和移动端 [youlai-app](https://gitee.com/youlaiorg/youlai-app),并提供 **6 种语言实现**(Java / Node.js / Go / Python / PHP / C#),共享同一套 API 规范与数据库结构。适用于企业中后台管理系统的学习参考与二次开发。
@@ -72,13 +77,13 @@
**环境要求**:JDK 17+ · MySQL 8.0+ · Redis 6.0+
1. 克隆项目:`git clone https://gitee.com/youlaiorg/youlai-boot.git`
-2. 导入数据库:`sql/mysql/youlai_admin.sql`
+2. 导入数据库:`sql/youlai-admin.sql`
3. 修改配置(可选,默认已配置线上只读数据源):`src/main/resources/application-dev.yml`
4. 启动服务,访问 http://localhost:8000/doc.html
默认账号:`admin` / `123456`
-**Docker 部署**:`cd docker && docker-compose up -d`
+**Docker 部署**:`cd deploy/docker`,然后 `docker-compose up -d`
详细指南:[部署文档](https://www.youlai.tech/docs/admin/backends/java/deploy) · [开发规范](https://www.youlai.tech/docs/admin/backends/java/dev-standards)
@@ -86,7 +91,7 @@
| 技术 | 版本 | 说明 |
|:-----|:-----|:-----|
-| Spring Boot | 4.0.1 | 核心框架 |
+| Spring Boot | 4.0.5 | 核心框架 |
| Spring Security | 6.x | 认证授权 |
| MyBatis-Plus | 3.5.15 | ORM 框架 |
| Druid | 1.2.24 | 数据库连接池 |
@@ -101,7 +106,9 @@
```
youlai-boot/
-├── docker/ # Docker 部署编排
+├── deploy/
+│ └── docker/ # Docker 部署编排
+├── docs/ # 项目文档与图片资源
├── sql/ # 数据库初始化脚本
├── src/main/java/com/youlai/boot/
│ ├── YouLaiBootApplication.java # 启动类
@@ -125,18 +132,25 @@ youlai-boot/
## 生态矩阵
-| 项目 | 技术栈 | 定位 |
-|:-----|:-------|:-----|
-| [**vue3-element-admin**](https://gitee.com/youlaiorg/vue3-element-admin) | Vue 3 + Element Plus | **PC 管理前端**(主推) |
-| [**youlai-app**](https://gitee.com/youlaiorg/youlai-app) | Vue 3 + UniApp | **移动端 App** |
-| [**youlai-boot-tenant**](https://gitee.com/youlaiorg/youlai-boot-tenant) | Spring Boot 4 | **SaaS 多租户版本** |
-| [**youlai-boot-flex**](https://gitee.com/youlaiorg/youlai-boot-flex) | Spring Boot 3 + MyBatis-Flex | MyBatis-Flex 版 |
-| [**youlai-nest**](https://gitee.com/youlaiorg/youlai-nest) | NestJS + TypeORM | **Node.js 后端** |
-| [**youlai-gin**](https://gitee.com/youlaiorg/youlai-gin) | Go + Gorm | **Go 后端** |
-| [**youlai-django**](https://gitee.com/youlaiorg/youlai-django) | Django + DRF | **Python 后端** |
-| [**youlai-thinkphp**](https://gitee.com/youlaiorg/youlai-thinkphp) | ThinkPHP 8 | **PHP 后端** |
-| [**youlai-aspnet**](https://gitee.com/youlaiorg/youlai-aspnet) | ASP.NET Core | **C# 后端** |
+**前端**
+| 项目 | 技术栈 | 说明 |
+|:-----|:-------|:-----|
+| [vue3-element-admin](https://gitee.com/youlaiorg/vue3-element-admin) | Vue 3 + Element Plus | PC 管理前端(主推) |
+| [youlai-app](https://gitee.com/youlaiorg/youlai-app) | Vue 3 + UniApp | 移动端 App |
+
+**后端**
+
+| 项目 | 技术栈 | 说明 |
+|:-----|:-------|:-----|
+| [youlai-nest](https://gitee.com/youlaiorg/youlai-nest) | NestJS + TypeORM | Node.js |
+| [youlai-gin](https://gitee.com/youlaiorg/youlai-gin) | Go + Gorm | Go |
+| [youlai-django](https://gitee.com/youlaiorg/youlai-django) | Django + DRF | Python |
+| [youlai-thinkphp](https://gitee.com/youlaiorg/youlai-thinkphp) | ThinkPHP 8 | PHP |
+| [youlai-aspnet](https://gitee.com/youlaiorg/youlai-aspnet) | ASP.NET Core | C# |
+
+> **youlai-boot** 还提供以下变种和分支版本:[多租户](https://gitee.com/youlaiorg/youlai-boot-tenant)(Spring Boot 4)· [MyBatis-Flex](https://gitee.com/youlaiorg/youlai-boot-flex)(Spring Boot 4)· [Spring Boot 3](https://gitee.com/youlaiorg/youlai-boot/tree/spring-boot-3) · [PostgreSQL](https://gitee.com/youlaiorg/youlai-boot/tree/db-pg) · [多模块](https://gitee.com/youlaiorg/youlai-boot/tree/multi-module)
+>
> 六种后端共享同一套 **RESTful API 规范** 和 **数据库结构**,前端可无缝切换。
## 文档资源
@@ -146,7 +160,7 @@ youlai-boot/
| 📖 完整文档站 | [www.youlai.tech/docs/admin](https://www.youlai.tech/docs/admin/) |
| 🖥️ PC 端在线预览 | [vue.youlai.tech](https://vue.youlai.tech) |
| 📱 移动端在线预览 | [app.youlai.tech](https://app.youlai.tech) |
-| 🔗 Apifox 接口文档 | [apifox.com](https://apifox.com/apidoc/shared-xxx) |
+| 🔗 Apifox 接口文档 | [apifox.com](https://www.apifox.cn/apidoc/shared-195e783f-4d85-4235-a038-eec696de4ea5) |
| 🔗 本地接口文档 | [localhost:8000/doc.html](http://localhost:8000/doc.html) |
## 参与贡献
@@ -161,14 +175,23 @@ youlai-boot/
---
-
-
-
-
-
-
- 公众号「有来技术」
-
- 添加作者微信
-
+
+
+
+ 
+ 公众号「有来技术」
+ |
+ |
+
+ 
+ 小程序「有来技术」
+ |
+ |
+
+ 
+ 添加作者微信
+ |
+
+
+
技术交流 · 问题反馈 · 商务合作
diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml
index 2144edd7..4e7c2841 100644
--- a/docker/docker-compose.yml
+++ b/docker/docker-compose.yml
@@ -15,7 +15,7 @@ services:
volumes:
- ./mysql/conf/my.cnf:/etc/my.cnf # 挂载 my.cnf 文件到容器的指定路径
- ./mysql/data:/var/lib/mysql # 持久化 MySQL 数据
- - ../sql/mysql:/docker-entrypoint-initdb.d # 初始化 SQL 脚本目录
+ - ../sql:/docker-entrypoint-initdb.d # 初始化 SQL 脚本目录
ports:
- 3306:3306
networks:
diff --git a/docs/images/qr/wechat-mp.jpg b/docs/images/qr/wechat-mp.jpg
new file mode 100644
index 00000000..8c06ee37
Binary files /dev/null and b/docs/images/qr/wechat-mp.jpg differ
diff --git a/pom.xml b/pom.xml
index 7a6fd2fc..6bbc8410 100644
--- a/pom.xml
+++ b/pom.xml
@@ -12,7 +12,7 @@
org.springframework.boot
spring-boot-starter-parent
- 4.0.1
+ 4.0.5
diff --git a/sql/mysql/youlai_admin_template.sql b/sql/mysql/youlai_admin_template.sql
deleted file mode 100644
index 48db9455..00000000
--- a/sql/mysql/youlai_admin_template.sql
+++ /dev/null
@@ -1,524 +0,0 @@
-# YouLai_Admin 数据库(MySQL 5.7 ~ MySQL 8.x)
-# Copyright (c) 2021-present, youlai.tech
-
-
--- ----------------------------
--- 1. 创建数据库
--- ----------------------------
-CREATE DATABASE IF NOT EXISTS youlai_admin_template CHARACTER SET utf8mb4 DEFAULT COLLATE utf8mb4_unicode_ci;
-
-
--- ----------------------------
--- 2. 创建表 && 数据初始化
--- ----------------------------
-USE youlai_admin_template;
-
-SET NAMES utf8mb4; # 设置字符集
-SET FOREIGN_KEY_CHECKS = 0; # 关闭外键检查,加快导入速度
-
--- ----------------------------
--- Table structure for sys_dept
--- ----------------------------
-DROP TABLE IF EXISTS `sys_dept`;
-CREATE TABLE `sys_dept` (
- `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
- `name` varchar(100) NOT NULL COMMENT '部门名称',
- `code` varchar(100) NOT NULL COMMENT '部门编号',
- `parent_id` bigint DEFAULT 0 COMMENT '父节点id',
- `tree_path` varchar(255) NOT NULL COMMENT '父节点id路径',
- `sort` smallint DEFAULT 0 COMMENT '显示顺序',
- `status` tinyint DEFAULT 1 COMMENT '状态(1-正常 0-禁用)',
- `create_by` bigint NULL COMMENT '创建人ID',
- `create_time` datetime NULL COMMENT '创建时间',
- `update_by` bigint NULL COMMENT '修改人ID',
- `update_time` datetime NULL COMMENT '更新时间',
- `is_deleted` tinyint DEFAULT 0 COMMENT '逻辑删除标识(1-已删除 0-未删除)',
- PRIMARY KEY (`id`) USING BTREE,
- UNIQUE INDEX `uk_code`(`code` ASC) USING BTREE COMMENT '部门编号唯一索引'
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '部门管理表';
-
--- ----------------------------
--- Records of sys_dept
--- ----------------------------
-INSERT INTO `sys_dept` VALUES (1, '有来技术', 'YOULAI', 0, '0', 1, 1, 1, NULL, 1, now(), 0);
-INSERT INTO `sys_dept` VALUES (2, '研发部门', 'RD001', 1, '0,1', 1, 1, 2, NULL, 2, now(), 0);
-INSERT INTO `sys_dept` VALUES (3, '测试部门', 'QA001', 1, '0,1', 1, 1, 2, NULL, 2, now(), 0);
-
--- ----------------------------
--- Table structure for sys_dict
--- ----------------------------
-DROP TABLE IF EXISTS `sys_dict`;
-CREATE TABLE `sys_dict` (
- `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键 ',
- `dict_code` varchar(50) COMMENT '类型编码',
- `name` varchar(50) COMMENT '类型名称',
- `status` tinyint(1) DEFAULT '0' COMMENT '状态(0:正常;1:禁用)',
- `remark` varchar(255) COMMENT '备注',
- `create_time` datetime COMMENT '创建时间',
- `create_by` bigint COMMENT '创建人ID',
- `update_time` datetime COMMENT '更新时间',
- `update_by` bigint COMMENT '修改人ID',
- `is_deleted` tinyint DEFAULT '0' COMMENT '是否删除(1-删除,0-未删除)',
- PRIMARY KEY (`id`) USING BTREE,
- KEY `idx_dict_code` (`dict_code`)
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='数据字典类型表';
--- ----------------------------
--- Records of sys_dict
--- ----------------------------
-INSERT INTO `sys_dict` VALUES (1, 'gender', '性别', 1, NULL, now() , 1,now(), 1,0);
-INSERT INTO `sys_dict` VALUES (2, 'notice_type', '通知类型', 1, NULL, now(), 1,now(), 1,0);
-INSERT INTO `sys_dict` VALUES (3, 'notice_level', '通知级别', 1, NULL, now(), 1,now(), 1,0);
-
-
--- ----------------------------
--- Table structure for sys_dict_item
--- ----------------------------
-DROP TABLE IF EXISTS `sys_dict_item`;
-CREATE TABLE `sys_dict_item` (
- `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键',
- `dict_code` varchar(50) COMMENT '关联字典编码,与sys_dict表中的dict_code对应',
- `value` varchar(50) COMMENT '字典项值',
- `label` varchar(100) COMMENT '字典项标签',
- `tag_type` varchar(50) COMMENT '标签类型,用于前端样式展示(如success、warning等)',
- `status` tinyint DEFAULT '0' COMMENT '状态(1-正常,0-禁用)',
- `sort` int DEFAULT '0' COMMENT '排序',
- `remark` varchar(255) COMMENT '备注',
- `create_time` datetime COMMENT '创建时间',
- `create_by` bigint COMMENT '创建人ID',
- `update_time` datetime COMMENT '更新时间',
- `update_by` bigint COMMENT '修改人ID',
- PRIMARY KEY (`id`) USING BTREE
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='数据字典项表';
-
--- ----------------------------
--- Records of sys_dict_item
--- ----------------------------
-INSERT INTO `sys_dict_item` VALUES (1, 'gender', '1', '男', 'primary', 1, 1, NULL, now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (2, 'gender', '2', '女', 'danger', 1, 2, NULL, now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (3, 'gender', '0', '保密', 'info', 1, 3, NULL, now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (4, 'notice_type', '1', '系统升级', 'success', 1, 1, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (5, 'notice_type', '2', '系统维护', 'primary', 1, 2, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (6, 'notice_type', '3', '安全警告', 'danger', 1, 3, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (7, 'notice_type', '4', '假期通知', 'success', 1, 4, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (8, 'notice_type', '5', '公司新闻', 'primary', 1, 5, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (9, 'notice_type', '99', '其他', 'info', 1, 99, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (10, 'notice_level', 'L', '低', 'info', 1, 1, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (11, 'notice_level', 'M', '中', 'warning', 1, 2, '', now(), 1,now(),1);
-INSERT INTO `sys_dict_item` VALUES (12, 'notice_level', 'H', '高', 'danger', 1, 3, '', now(), 1,now(),1);
-
--- ----------------------------
--- Table structure for sys_menu
--- ----------------------------
-DROP TABLE IF EXISTS `sys_menu`;
-CREATE TABLE `sys_menu` (
- `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'ID',
- `parent_id` bigint NOT NULL COMMENT '父菜单ID',
- `tree_path` varchar(255) COMMENT '父节点ID路径',
- `name` varchar(64) NOT NULL COMMENT '菜单名称',
- `type` char(1) NOT NULL COMMENT '菜单类型(C-目录 M-菜单 B-按钮)',
- `route_name` varchar(255) COMMENT '路由名称(Vue Router 中用于命名路由)',
- `route_path` varchar(128) COMMENT '路由路径(Vue Router 中定义的 URL 路径)',
- `component` varchar(128) COMMENT '组件路径(组件页面完整路径,相对于 src/views/,缺省后缀 .vue)',
- `perm` varchar(128) COMMENT '【按钮】权限标识',
- `always_show` tinyint DEFAULT 0 COMMENT '【目录】只有一个子路由是否始终显示(1-是 0-否)',
- `keep_alive` tinyint DEFAULT 0 COMMENT '【菜单】是否开启页面缓存(1-是 0-否)',
- `visible` tinyint(1) DEFAULT 1 COMMENT '显示状态(1-显示 0-隐藏)',
- `sort` int DEFAULT 0 COMMENT '排序',
- `icon` varchar(64) COMMENT '菜单图标',
- `redirect` varchar(128) COMMENT '跳转路径',
- `create_time` datetime NULL COMMENT '创建时间',
- `update_time` datetime NULL COMMENT '更新时间',
- `params` varchar(255) NULL COMMENT '路由参数',
- PRIMARY KEY (`id`) USING BTREE
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '系统菜单表';
-
--- ----------------------------
--- Records of sys_menu
--- ----------------------------
--- 顶级目录:系统管理/代码生成/平台文档/接口文档
-INSERT INTO `sys_menu` VALUES (1, 0, '0', '系统管理', 'C', '', '/system', 'Layout', NULL, NULL, NULL, 1, 1, 'system', '/system/user', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2, 0, '0', '代码生成', 'C', '', '/codegen', 'Layout', NULL, NULL, NULL, 1, 2, 'code', '/codegen/index', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (4, 0, '0', '平台文档', 'C', '', '/doc', 'Layout', NULL, NULL, NULL, 1, 4, 'document', '', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (5, 0, '0', '接口文档', 'C', '', '/api', 'Layout', NULL, NULL, NULL, 1, 5, 'api', '', now(), now(), NULL);
-
--- 系统管理
-INSERT INTO `sys_menu` VALUES (210, 1, '0,1', '用户管理', 'M', 'User', 'user', 'system/user/index', NULL, NULL, 1, 1, 1, 'el-icon-User', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2101, 210, '0,1,210', '用户查询', 'B', NULL, '', NULL, 'sys:user:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2102, 210, '0,1,210', '用户新增', 'B', NULL, '', NULL, 'sys:user:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2103, 210, '0,1,210', '用户编辑', 'B', NULL, '', NULL, 'sys:user:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2104, 210, '0,1,210', '用户删除', 'B', NULL, '', NULL, 'sys:user:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2105, 210, '0,1,210', '重置密码', 'B', NULL, '', NULL, 'sys:user:reset-password', NULL, NULL, 1, 5, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2106, 210, '0,1,210', '用户导入', 'B', NULL, '', NULL, 'sys:user:import', NULL, NULL, 1, 6, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2107, 210, '0,1,210', '用户导出', 'B', NULL, '', NULL, 'sys:user:export', NULL, NULL, 1, 7, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (220, 1, '0,1', '角色管理', 'M', 'Role', 'role', 'system/role/index', NULL, NULL, 1, 1, 2, 'role', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2201, 220, '0,1,220', '角色查询', 'B', NULL, '', NULL, 'sys:role:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2202, 220, '0,1,220', '角色新增', 'B', NULL, '', NULL, 'sys:role:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2203, 220, '0,1,220', '角色编辑', 'B', NULL, '', NULL, 'sys:role:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2204, 220, '0,1,220', '角色删除', 'B', NULL, '', NULL, 'sys:role:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2205, 220, '0,1,220', '角色分配权限', 'B', NULL, '', NULL, 'sys:role:assign', NULL, NULL, 1, 5, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (230, 1, '0,1', '菜单管理', 'M', 'SysMenu', 'menu', 'system/menu/index', NULL, NULL, 1, 1, 3, 'menu', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2301, 230, '0,1,230', '菜单查询', 'B', NULL, '', NULL, 'sys:menu:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2302, 230, '0,1,230', '菜单新增', 'B', NULL, '', NULL, 'sys:menu:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2303, 230, '0,1,230', '菜单编辑', 'B', NULL, '', NULL, 'sys:menu:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2304, 230, '0,1,230', '菜单删除', 'B', NULL, '', NULL, 'sys:menu:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (240, 1, '0,1', '部门管理', 'M', 'Dept', 'dept', 'system/dept/index', NULL, NULL, 1, 1, 4, 'tree', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2401, 240, '0,1,240', '部门查询', 'B', NULL, '', NULL, 'sys:dept:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2402, 240, '0,1,240', '部门新增', 'B', NULL, '', NULL, 'sys:dept:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2403, 240, '0,1,240', '部门编辑', 'B', NULL, '', NULL, 'sys:dept:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2404, 240, '0,1,240', '部门删除', 'B', NULL, '', NULL, 'sys:dept:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (250, 1, '0,1', '字典管理', 'M', 'Dict', 'dict', 'system/dict/index', NULL, NULL, 1, 1, 5, 'dict', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2501, 250, '0,1,250', '字典查询', 'B', NULL, '', NULL, 'sys:dict:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2502, 250, '0,1,250', '字典新增', 'B', NULL, '', NULL, 'sys:dict:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2503, 250, '0,1,250', '字典编辑', 'B', NULL, '', NULL, 'sys:dict:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2504, 250, '0,1,250', '字典删除', 'B', NULL, '', NULL, 'sys:dict:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (251, 1, '0,1', '字典项', 'M', 'DictItem', 'dict-item', 'system/dict/dict-item', NULL, 0, 1, 0, 6, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2511, 251, '0,1,251', '字典项查询', 'B', NULL, '', NULL, 'sys:dict-item:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2512, 251, '0,1,251', '字典项新增', 'B', NULL, '', NULL, 'sys:dict-item:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2513, 251, '0,1,251', '字典项编辑', 'B', NULL, '', NULL, 'sys:dict-item:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2514, 251, '0,1,251', '字典项删除', 'B', NULL, '', NULL, 'sys:dict-item:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (260, 1, '0,1', '系统日志', 'M', 'Log', 'log', 'system/log/index', NULL, 0, 1, 1, 7, 'document', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (270, 1, '0,1', '系统配置', 'M', 'Config', 'config', 'system/config/index', NULL, 0, 1, 1, 8, 'setting', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2701, 270, '0,1,270', '系统配置查询', 'B', NULL, '', NULL, 'sys:config:list', 0, 1, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2702, 270, '0,1,270', '系统配置新增', 'B', NULL, '', NULL, 'sys:config:create', 0, 1, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2703, 270, '0,1,270', '系统配置修改', 'B', NULL, '', NULL, 'sys:config:update', 0, 1, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2704, 270, '0,1,270', '系统配置删除', 'B', NULL, '', NULL, 'sys:config:delete', 0, 1, 1, 4, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2705, 270, '0,1,270', '系统配置刷新', 'B', NULL, '', NULL, 'sys:config:refresh', 0, 1, 1, 5, '', NULL, now(), now(), NULL);
-
-INSERT INTO `sys_menu` VALUES (280, 1, '0,1', '通知公告', 'M', 'Notice', 'notice', 'system/notice/index', NULL, NULL, NULL, 1, 9, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2801, 280, '0,1,280', '通知查询', 'B', NULL, '', NULL, 'sys:notice:list', NULL, NULL, 1, 1, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2802, 280, '0,1,280', '通知新增', 'B', NULL, '', NULL, 'sys:notice:create', NULL, NULL, 1, 2, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2803, 280, '0,1,280', '通知编辑', 'B', NULL, '', NULL, 'sys:notice:update', NULL, NULL, 1, 3, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2804, 280, '0,1,280', '通知删除', 'B', NULL, '', NULL, 'sys:notice:delete', NULL, NULL, 1, 4, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2805, 280, '0,1,280', '通知发布', 'B', NULL, '', NULL, 'sys:notice:publish', 0, 1, 1, 5, '', NULL, now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (2806, 280, '0,1,280', '通知撤回', 'B', NULL, '', NULL, 'sys:notice:revoke', 0, 1, 1, 6, '', NULL, now(), now(), NULL);
-
--- 代码生成
-INSERT INTO `sys_menu` VALUES (310, 2, '0,2', '代码生成', 'M', 'Codegen', 'codegen', 'codegen/index', NULL, NULL, 1, 1, 1, 'code', NULL, now(), now(), NULL);
-
--- 平台文档(外链通过 route_path 识别)
-INSERT INTO `sys_menu` VALUES (501, 4, '0,4', '平台文档(外链)', 'M', NULL, 'https://juejin.cn/post/7228990409909108793', '', NULL, NULL, NULL, 1, 1, 'document', '', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (502, 4, '0,4', '后端文档', 'M', NULL, 'https://youlai.blog.csdn.net/article/details/145178880', '', NULL, NULL, NULL, 1, 2, 'document', '', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (503, 4, '0,4', '移动端文档', 'M', NULL, 'https://youlai.blog.csdn.net/article/details/143222890', '', NULL, NULL, NULL, 1, 3, 'document', '', now(), now(), NULL);
-INSERT INTO `sys_menu` VALUES (504, 4, '0,4', '内部文档', 'M', NULL, 'internal-doc', 'demo/internal-doc', NULL, NULL, NULL, 1, 4, 'document', '', now(), now(), NULL);
-
--- 接口文档
-INSERT INTO `sys_menu` VALUES (601, 5, '0,5', 'Apifox', 'M', 'Apifox', 'apifox', 'demo/api/apifox', NULL, NULL, 1, 1, 1, 'api', '', now(), now(), NULL);
-
--- ----------------------------
--- Table structure for sys_role
--- ----------------------------
-DROP TABLE IF EXISTS `sys_role`;
-CREATE TABLE `sys_role` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `name` varchar(64) NOT NULL COMMENT '角色名称',
- `code` varchar(32) NOT NULL COMMENT '角色编码',
- `sort` int NULL COMMENT '显示顺序',
- `status` tinyint(1) DEFAULT 1 COMMENT '角色状态(1-正常 0-停用)',
- `data_scope` tinyint NULL COMMENT '数据权限(1-所有数据 2-部门及子部门数据 3-本部门数据 4-本人数据 5-自定义部门数据)',
- `create_by` bigint NULL COMMENT '创建人 ID',
- `create_time` datetime NULL COMMENT '创建时间',
- `update_by` bigint NULL COMMENT '更新人ID',
- `update_time` datetime NULL COMMENT '更新时间',
- `is_deleted` tinyint(1) DEFAULT 0 COMMENT '逻辑删除标识(0-未删除 1-已删除)',
- PRIMARY KEY (`id`) USING BTREE,
- UNIQUE INDEX `uk_name`(`name` ASC) USING BTREE COMMENT '角色名称唯一索引',
- UNIQUE INDEX `uk_code`(`code` ASC) USING BTREE COMMENT '角色编码唯一索引'
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '系统角色表';
-
--- ----------------------------
--- Records of sys_role
--- ----------------------------
-INSERT INTO `sys_role` VALUES (1, '超级管理员', 'ROOT', 1, 1, 1, NULL, now(), NULL, now(), 0);
-INSERT INTO `sys_role` VALUES (2, '系统管理员', 'ADMIN', 2, 1, 1, NULL, now(), NULL, NULL, 0);
-INSERT INTO `sys_role` VALUES (3, '访问游客', 'GUEST', 3, 1, 3, NULL, now(), NULL, now(), 0);
-INSERT INTO `sys_role` VALUES (4, '部门主管', 'DEPT_MANAGER', 4, 1, 2, NULL, now(), NULL, now(), 0);
-INSERT INTO `sys_role` VALUES (5, '部门成员', 'DEPT_MEMBER', 5, 1, 3, NULL, now(), NULL, now(), 0);
-INSERT INTO `sys_role` VALUES (6, '普通员工', 'EMPLOYEE', 6, 1, 4, NULL, now(), NULL, now(), 0);
-INSERT INTO `sys_role` VALUES (7, '自定义权限用户', 'CUSTOM_USER', 7, 1, 5, NULL, now(), NULL, now(), 0);
-
--- ----------------------------
--- Table structure for sys_role_menu
--- ----------------------------
-DROP TABLE IF EXISTS `sys_role_menu`;
-CREATE TABLE `sys_role_menu` (
- `role_id` bigint NOT NULL COMMENT '角色ID',
- `menu_id` bigint NOT NULL COMMENT '菜单ID',
- UNIQUE INDEX `uk_roleid_menuid`(`role_id` ASC, `menu_id` ASC) USING BTREE COMMENT '角色菜单唯一索引'
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '角色菜单关联表';
-
--- ----------------------------
--- Table structure for sys_role_dept
--- ----------------------------
-DROP TABLE IF EXISTS `sys_role_dept`;
-CREATE TABLE `sys_role_dept` (
- `role_id` bigint NOT NULL COMMENT '角色ID',
- `dept_id` bigint NOT NULL COMMENT '部门ID',
- UNIQUE INDEX `uk_roleid_deptid`(`role_id` ASC, `dept_id` ASC) USING BTREE COMMENT '角色部门唯一索引'
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '角色部门关联表';
-
--- ----------------------------
--- Records of sys_role_dept
--- ----------------------------
-INSERT IGNORE INTO `sys_role_dept` VALUES (7, 1);
-INSERT IGNORE INTO `sys_role_dept` VALUES (7, 2);
-
--- ============================================
--- 系统管理员角色菜单权限(role_id=2)
--- 顶级目录
-INSERT INTO `sys_role_menu` VALUES (2, 1), (2, 2), (2, 4), (2, 5);
--- 系统管理
-INSERT INTO `sys_role_menu` VALUES (2, 210), (2, 2101), (2, 2102), (2, 2103), (2, 2104), (2, 2105), (2, 2106), (2, 2107);
-INSERT INTO `sys_role_menu` VALUES (2, 220), (2, 2201), (2, 2202), (2, 2203), (2, 2204), (2, 2205);
-INSERT INTO `sys_role_menu` VALUES (2, 230), (2, 2301), (2, 2302), (2, 2303), (2, 2304);
-INSERT INTO `sys_role_menu` VALUES (2, 240), (2, 2401), (2, 2402), (2, 2403), (2, 2404);
-INSERT INTO `sys_role_menu` VALUES (2, 250), (2, 2501), (2, 2502), (2, 2503), (2, 2504);
-INSERT INTO `sys_role_menu` VALUES (2, 251), (2, 2511), (2, 2512), (2, 2513), (2, 2514);
-INSERT INTO `sys_role_menu` VALUES (2, 260), (2, 2601);
-INSERT INTO `sys_role_menu` VALUES (2, 270), (2, 2701), (2, 2702), (2, 2703), (2, 2704), (2, 2705);
-INSERT INTO `sys_role_menu` VALUES (2, 280), (2, 2801), (2, 2802), (2, 2803), (2, 2804), (2, 2805), (2, 2806);
-
-INSERT IGNORE INTO `sys_role_menu` VALUES (4, 1);
-INSERT IGNORE INTO `sys_role_menu` VALUES (4, 210), (4, 2101), (4, 2102), (4, 2103), (4, 2104), (4, 2105), (4, 2106), (4, 2107);
-INSERT IGNORE INTO `sys_role_menu` VALUES (4, 220), (4, 2201), (4, 2202), (4, 2203), (4, 2204), (4, 2205);
-
-INSERT IGNORE INTO `sys_role_menu` VALUES (5, 1);
-INSERT IGNORE INTO `sys_role_menu` VALUES (5, 210), (5, 2101), (5, 2102), (5, 2103), (5, 2104), (5, 2105), (5, 2106), (5, 2107);
-INSERT IGNORE INTO `sys_role_menu` VALUES (5, 220), (5, 2201), (5, 2202), (5, 2203), (5, 2204), (5, 2205);
-
-INSERT IGNORE INTO `sys_role_menu` VALUES (6, 1);
-INSERT IGNORE INTO `sys_role_menu` VALUES (6, 210), (6, 2101), (6, 2102), (6, 2103), (6, 2104), (6, 2105), (6, 2106), (6, 2107);
-INSERT IGNORE INTO `sys_role_menu` VALUES (6, 220), (6, 2201), (6, 2202), (6, 2203), (6, 2204), (6, 2205);
-
-INSERT IGNORE INTO `sys_role_menu` VALUES (7, 1);
-INSERT IGNORE INTO `sys_role_menu` VALUES (7, 210), (7, 2101), (7, 2102), (7, 2103), (7, 2104), (7, 2105), (7, 2106), (7, 2107);
-INSERT IGNORE INTO `sys_role_menu` VALUES (7, 220), (7, 2201), (7, 2202), (7, 2203), (7, 2204), (7, 2205);
--- 代码生成
-INSERT INTO `sys_role_menu` VALUES (2, 310);
--- 平台文档
-INSERT INTO `sys_role_menu` VALUES (2, 501), (2, 502), (2, 503), (2, 504);
--- 接口文档
-INSERT INTO `sys_role_menu` VALUES (2, 601);
-
--- ----------------------------
--- Table structure for sys_user
--- ----------------------------
-DROP TABLE IF EXISTS `sys_user`;
-CREATE TABLE `sys_user` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `username` varchar(64) COMMENT '用户名',
- `nickname` varchar(64) COMMENT '昵称',
- `gender` tinyint(1) DEFAULT 1 COMMENT '性别((1-男 2-女 0-保密)',
- `password` varchar(100) COMMENT '密码',
- `dept_id` int COMMENT '部门ID',
- `avatar` varchar(255) COMMENT '用户头像',
- `mobile` varchar(20) COMMENT '联系方式',
- `status` tinyint(1) DEFAULT 1 COMMENT '状态(1-正常 0-禁用)',
- `email` varchar(128) COMMENT '用户邮箱',
- `create_time` datetime COMMENT '创建时间',
- `create_by` bigint COMMENT '创建人ID',
- `update_time` datetime COMMENT '更新时间',
- `update_by` bigint COMMENT '修改人ID',
- `is_deleted` tinyint(1) DEFAULT 0 COMMENT '逻辑删除标识(0-未删除 1-已删除)',
- PRIMARY KEY (`id`) USING BTREE
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '系统用户表';
-
--- ----------------------------
--- Records of sys_user
--- ----------------------------
-INSERT INTO `sys_user` VALUES (1, 'root', '有来技术', 0, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', NULL, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345677', 1, 'youlaitech@163.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (2, 'admin', '系统管理员', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 1, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18888888888', 1, 'youlaitech@163.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (3, 'test', '测试小用户', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 3, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345679', 1, 'youlaitech@163.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (4, 'dept_manager', '部门主管', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 1, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345680', 1, 'manager@youlaitech.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (5, 'dept_member', '部门成员', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 1, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345681', 1, 'member@youlaitech.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (6, 'employee', '普通员工', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 2, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345682', 1, 'employee@youlaitech.com', now(), NULL, now(), NULL, 0);
-INSERT INTO `sys_user` VALUES (7, 'custom_user', '自定义权限用户', 1, '$2a$10$xVWsNOhHrCxh5UbpCE7/HuJ.PAOKcYAqRxD2CO2nVnJS.IAXkr5aq', 3, 'https://foruda.gitee.com/images/1723603502796844527/03cdca2a_716974.gif', '18812345683', 1, 'custom@youlaitech.com', now(), NULL, now(), NULL, 0);
-
--- ----------------------------
--- Table structure for sys_user_role
--- ----------------------------
-DROP TABLE IF EXISTS `sys_user_role`;
-CREATE TABLE `sys_user_role` (
- `user_id` bigint NOT NULL COMMENT '用户ID',
- `role_id` bigint NOT NULL COMMENT '角色ID',
- PRIMARY KEY (`user_id`, `role_id`) USING BTREE
-) ENGINE = InnoDB CHARACTER SET = utf8mb4 COMMENT = '用户角色关联表';
-
--- ----------------------------
--- Records of sys_user_role
--- ----------------------------
-INSERT INTO `sys_user_role` VALUES (1, 1);
-INSERT INTO `sys_user_role` VALUES (2, 2);
-INSERT INTO `sys_user_role` VALUES (3, 3);
-INSERT IGNORE INTO `sys_user_role` VALUES (4, 4);
-INSERT IGNORE INTO `sys_user_role` VALUES (5, 5);
-INSERT IGNORE INTO `sys_user_role` VALUES (6, 6);
-INSERT IGNORE INTO `sys_user_role` VALUES (7, 7);
-
--- ----------------------------
--- Table structure for sys_log
--- ----------------------------
-DROP TABLE IF EXISTS `sys_log`;
-CREATE TABLE `sys_log` (
- `id` BIGINT NOT NULL AUTO_INCREMENT COMMENT '主键',
- `module` TINYINT NOT NULL COMMENT '模块,数字枚举,参考 LogModule 枚举',
- `action_type` TINYINT NOT NULL COMMENT '操作类型,数字枚举,参考 ActionType 枚举',
- `title` VARCHAR(100) NOT NULL COMMENT '前端显示标题',
- `content` TEXT COMMENT '自定义日志内容',
- `operator_id` BIGINT COMMENT '操作人ID',
- `operator_name` VARCHAR(50) COMMENT '操作人名称',
- `request_uri` VARCHAR(255) COMMENT '请求路径',
- `request_method` VARCHAR(10) COMMENT '请求方法',
- `ip` VARCHAR(45) COMMENT 'IP地址',
- `province` VARCHAR(100) COMMENT '省份',
- `city` VARCHAR(100) COMMENT '城市',
- `device` VARCHAR(100) COMMENT '设备',
- `os` VARCHAR(100) COMMENT '操作系统',
- `browser` VARCHAR(100) COMMENT '浏览器',
- `status` TINYINT DEFAULT 1 COMMENT '0失败 1成功',
- `error_msg` VARCHAR(255) COMMENT '错误信息',
- `execution_time` INT COMMENT '执行时间(ms)',
- `create_time` DATETIME COMMENT '操作时间',
- PRIMARY KEY (`id`) USING BTREE,
- KEY `idx_module_action_time` (`module`, `action_type`, `create_time`),
- KEY `idx_operator_time` (`operator_id`, `create_time`),
- KEY `idx_time` (`create_time`)
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='系统操作日志表';
-
--- ----------------------------
--- Table structure for gen_table
--- ----------------------------
-DROP TABLE IF EXISTS `gen_table`;
-CREATE TABLE `gen_table` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `table_name` varchar(100) NOT NULL COMMENT '表名',
- `module_name` varchar(100) COMMENT '模块名',
- `package_name` varchar(255) NOT NULL COMMENT '包名',
- `business_name` varchar(100) NOT NULL COMMENT '业务名',
- `entity_name` varchar(100) NOT NULL COMMENT '实体类名',
- `author` varchar(50) NOT NULL COMMENT '作者',
- `parent_menu_id` bigint COMMENT '上级菜单ID,对应sys_menu的id ',
- `remove_table_prefix` varchar(20) COMMENT '要移除的表前缀,如: sys_',
- `page_type` varchar(20) COMMENT '页面类型(classic|curd)',
- `create_time` datetime COMMENT '创建时间',
- `update_time` datetime COMMENT '更新时间',
- `is_deleted` tinyint(4) DEFAULT 0 COMMENT '是否删除',
- PRIMARY KEY (`id`),
- UNIQUE KEY `uk_tablename` (`table_name`)
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='代码生成配置表';
-
--- ----------------------------
--- Table structure for gen_table_column
--- ----------------------------
-DROP TABLE IF EXISTS `gen_table_column`;
-CREATE TABLE `gen_table_column` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `table_id` bigint NOT NULL COMMENT '关联的表配置ID',
- `column_name` varchar(100) ,
- `column_type` varchar(50) ,
- `column_length` int ,
- `field_name` varchar(100) NOT NULL COMMENT '字段名称',
- `field_type` varchar(100) COMMENT '字段类型',
- `field_sort` int COMMENT '字段排序',
- `field_comment` varchar(255) COMMENT '字段描述',
- `max_length` int ,
- `is_required` tinyint(1) COMMENT '是否必填',
- `is_show_in_list` tinyint(1) DEFAULT '0' COMMENT '是否在列表显示',
- `is_show_in_form` tinyint(1) DEFAULT '0' COMMENT '是否在表单显示',
- `is_show_in_query` tinyint(1) DEFAULT '0' COMMENT '是否在查询条件显示',
- `query_type` tinyint COMMENT '查询方式',
- `form_type` tinyint COMMENT '表单类型',
- `dict_type` varchar(50) COMMENT '字典类型',
- `create_time` datetime COMMENT '创建时间',
- `update_time` datetime COMMENT '更新时间',
- PRIMARY KEY (`id`),
- KEY `idx_table_id` (`table_id`)
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='代码生成字段配置表';
-
--- ----------------------------
--- 系统配置表
--- ----------------------------
-DROP TABLE IF EXISTS `sys_config`;
-CREATE TABLE `sys_config` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `config_name` varchar(50) NOT NULL COMMENT '配置名称',
- `config_key` varchar(50) NOT NULL COMMENT '配置key',
- `config_value` varchar(100) NOT NULL COMMENT '配置值',
- `remark` varchar(255) COMMENT '备注',
- `create_time` datetime COMMENT '创建时间',
- `create_by` bigint COMMENT '创建人ID',
- `update_time` datetime COMMENT '更新时间',
- `update_by` bigint COMMENT '更新人ID',
- `is_deleted` tinyint(4) DEFAULT '0' NOT NULL COMMENT '逻辑删除标识(0-未删除 1-已删除)',
- PRIMARY KEY (`id`)
-) ENGINE=InnoDB COMMENT='系统配置表';
-
-INSERT INTO `sys_config` VALUES (1, '系统限流QPS', 'IP_QPS_THRESHOLD_LIMIT', '10', '单个IP请求的最大每秒查询数(QPS)阈值Key', now(), 1, NULL, NULL, 0);
-
--- ----------------------------
--- 通知公告表
--- ----------------------------
-DROP TABLE IF EXISTS `sys_notice`;
-CREATE TABLE `sys_notice` (
- `id` bigint NOT NULL AUTO_INCREMENT,
- `title` varchar(50) COMMENT '通知标题',
- `content` text COMMENT '通知内容',
- `type` tinyint NOT NULL COMMENT '通知类型(关联字典编码:notice_type)',
- `level` varchar(5) NOT NULL COMMENT '通知等级(字典code:notice_level)',
- `target_type` tinyint NOT NULL COMMENT '目标类型(1: 全体, 2: 指定)',
- `target_user_ids` varchar(255) COMMENT '目标人ID集合(多个使用英文逗号,分割)',
- `publisher_id` bigint COMMENT '发布人ID',
- `publish_status` tinyint DEFAULT '0' COMMENT '发布状态(0: 未发布, 1: 已发布, -1: 已撤回)',
- `publish_time` datetime COMMENT '发布时间',
- `revoke_time` datetime COMMENT '撤回时间',
- `create_by` bigint NOT NULL COMMENT '创建人ID',
- `create_time` datetime NOT NULL COMMENT '创建时间',
- `update_by` bigint COMMENT '更新人ID',
- `update_time` datetime COMMENT '更新时间',
- `is_deleted` tinyint(1) DEFAULT '0' COMMENT '是否删除(0: 未删除, 1: 已删除)',
- PRIMARY KEY (`id`) USING BTREE
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='系统通知公告表';
-
-INSERT INTO `sys_notice` VALUES (1, 'v3.0.0 版本发布 - 多租户功能上线', '🎉 新版本发布,主要更新内容:
1. 新增多租户功能,支持租户隔离和数据管理
2. 优化系统性能,提升响应速度
3. 完善权限管理,增强安全性
4. 修复已知问题,提升系统稳定性
', 1, 'H', 1, NULL, 1, 1, '2024-12-15 10:00:00', NULL, 1, '2024-12-15 10:00:00', 1, '2024-12-15 10:00:00', 0);
-INSERT INTO `sys_notice` VALUES (2, '系统维护通知 - 2024年12月20日', '⏰ 系统维护通知
系统将于 2024年12月20日(本周五)凌晨 2:00-4:00 进行例行维护升级。
维护期间系统将暂停服务,请提前做好数据备份工作。
给您带来的不便,敬请谅解!
', 2, 'H', 1, NULL, 1, 1, '2024-12-18 14:30:00', NULL, 1, '2024-12-18 14:30:00', 1, '2024-12-18 14:30:00', 0);
-INSERT INTO `sys_notice` VALUES (3, '安全提醒 - 防范钓鱼邮件', '⚠️ 安全提醒
近期发现有不法分子通过钓鱼邮件进行网络攻击,请大家提高警惕:
1. 不要点击来源不明的邮件链接
2. 不要下载可疑附件
3. 遇到可疑邮件请及时联系IT部门
4. 定期修改密码,使用强密码策略
', 3, 'H', 1, NULL, 1, 1, '2024-12-10 09:00:00', NULL, 1, '2024-12-10 09:00:00', 1, '2024-12-10 09:00:00', 0);
-INSERT INTO `sys_notice` VALUES (4, '元旦假期安排通知', '📅 元旦假期安排
根据国家法定节假日安排,公司元旦假期时间为:
2024年12月30日(周一)至 2025年1月1日(周三),共3天。
2024年12月29日(周日)正常上班。
祝大家元旦快乐,假期愉快!
', 4, 'M', 1, NULL, 1, 1, '2024-12-25 16:00:00', NULL, 1, '2024-12-25 16:00:00', 1, '2024-12-25 16:00:00', 0);
-INSERT INTO `sys_notice` VALUES (5, '新产品发布会邀请', '🎊 新产品发布会邀请
公司将于 2025年1月15日下午14:00 在总部会议室举办新产品发布会。
届时将展示最新研发的产品和技术成果,欢迎全体员工参加。
请各部门提前安排好工作,准时参加。
', 5, 'M', 1, NULL, 1, 1, '2024-12-28 11:00:00', NULL, 1, '2024-12-28 11:00:00', 1, '2024-12-28 11:00:00', 0);
-INSERT INTO `sys_notice` VALUES (6, 'v2.16.1 版本更新', '✨ 版本更新
v2.16.1 版本已发布,主要修复内容:
1. 修复 WebSocket 重复连接导致的后台线程阻塞问题
2. 优化通知公告功能,提升用户体验
3. 修复部分已知bug
建议尽快更新到最新版本。
', 1, 'M', 1, NULL, 1, 1, '2024-12-05 15:30:00', NULL, 1, '2024-12-05 15:30:00', 1, '2024-12-05 15:30:00', 0);
-INSERT INTO `sys_notice` VALUES (7, '年终总结会议通知', '📋 年终总结会议通知
各部门年终总结会议将于 2024年12月30日上午9:00 召开。
请各部门负责人提前准备好年度工作总结和下年度工作计划。
会议地点:总部大会议室
', 5, 'M', 2, '1,2', 1, 1, '2024-12-22 10:00:00', NULL, 1, '2024-12-22 10:00:00', 1, '2024-12-22 10:00:00', 0);
-INSERT INTO `sys_notice` VALUES (8, '系统功能优化完成', '✅ 系统功能优化
已完成以下功能优化:
1. 优化用户管理界面,提升操作体验
2. 增强数据导出功能,支持更多格式
3. 优化搜索功能,提升查询效率
4. 修复部分界面显示问题
', 1, 'L', 1, NULL, 1, 1, '2024-12-12 14:20:00', NULL, 1, '2024-12-12 14:20:00', 1, '2024-12-12 14:20:00', 0);
-INSERT INTO `sys_notice` VALUES (9, '员工培训计划', '📚 员工培训计划
为提升员工专业技能,公司将于 2025年1月8日-10日 组织技术培训。
培训内容:
1. 新技术框架应用
2. 代码规范与最佳实践
3. 系统架构设计
请各部门合理安排工作,确保培训顺利进行。
', 5, 'M', 1, NULL, 1, 1, '2024-12-20 09:30:00', NULL, 1, '2024-12-20 09:30:00', 1, '2024-12-20 09:30:00', 0);
-INSERT INTO `sys_notice` VALUES (10, '数据备份提醒', '💾 数据备份提醒
请各部门注意定期备份重要数据,建议每周至少备份一次。
备份方式:
1. 使用系统自带备份功能
2. 手动导出重要数据
3. 联系IT部门协助备份
数据安全,人人有责!
', 3, 'L', 1, NULL, 1, 1, '2024-12-08 08:00:00', NULL, 1, '2024-12-08 08:00:00', 1, '2024-12-08 08:00:00', 0);
-
--- ----------------------------
--- 用户通知公告表
--- ----------------------------
-DROP TABLE IF EXISTS `sys_user_notice`;
-CREATE TABLE `sys_user_notice` (
- `id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',
- `notice_id` bigint NOT NULL COMMENT '公共通知id',
- `user_id` bigint NOT NULL COMMENT '用户id',
- `is_read` bigint DEFAULT '0' COMMENT '读取状态(0: 未读, 1: 已读)',
- `read_time` datetime COMMENT '阅读时间',
- `create_time` datetime NOT NULL COMMENT '创建时间',
- `update_time` datetime COMMENT '更新时间',
- `is_deleted` tinyint DEFAULT '0' COMMENT '逻辑删除(0: 未删除, 1: 已删除)',
- PRIMARY KEY (`id`) USING BTREE
-) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户通知公告关联表';
-
-INSERT INTO `sys_user_notice` VALUES (1, 1, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (2, 2, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (3, 3, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (4, 4, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (5, 5, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (6, 6, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (7, 7, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (8, 8, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (9, 9, 2, 1, NULL, now(), now(), 0);
-INSERT INTO `sys_user_notice` VALUES (10, 10, 2, 1, NULL, now(), now(), 0);
diff --git a/sql/mysql/youlai_admin.sql b/sql/youlai-admin.sql
similarity index 100%
rename from sql/mysql/youlai_admin.sql
rename to sql/youlai-admin.sql
diff --git a/src/main/java/com/youlai/boot/YouLaiBootApplication.java b/src/main/java/com/youlai/boot/YouLaiBootApplication.java
index 6c44e203..a40fcaaa 100644
--- a/src/main/java/com/youlai/boot/YouLaiBootApplication.java
+++ b/src/main/java/com/youlai/boot/YouLaiBootApplication.java
@@ -2,6 +2,7 @@ package com.youlai.boot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.scheduling.annotation.EnableScheduling;
/**
* 应用启动类
@@ -9,6 +10,7 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
* @author Ray.Hao
* @since 0.0.1
*/
+@EnableScheduling
@SpringBootApplication
public class YouLaiBootApplication {
diff --git a/src/main/java/com/youlai/boot/message/registry/SseSessionRegistry.java b/src/main/java/com/youlai/boot/message/registry/SseSessionRegistry.java
index 502ec3a4..f6923b41 100644
--- a/src/main/java/com/youlai/boot/message/registry/SseSessionRegistry.java
+++ b/src/main/java/com/youlai/boot/message/registry/SseSessionRegistry.java
@@ -6,10 +6,12 @@ import org.springframework.context.event.ContextClosedEvent;
import org.springframework.context.event.EventListener;
import org.springframework.core.Ordered;
import org.springframework.core.annotation.Order;
+import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
import java.io.IOException;
+import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;
@@ -198,6 +200,28 @@ public class SseSessionRegistry {
}
}
+ /**
+ * 心跳检测:每30秒向所有连接发送ping事件,及时清理已断开的僵尸连接
+ */
+ @Scheduled(fixedRate = 30000)
+ public void heartbeat() {
+ if (emitterUserMap.isEmpty()) {
+ return;
+ }
+ List failedEmitters = new ArrayList<>();
+ for (SseEmitter emitter : emitterUserMap.keySet()) {
+ try {
+ emitter.send(SseEmitter.event().name("ping").data("heartbeat"));
+ } catch (Exception e) {
+ failedEmitters.add(emitter);
+ }
+ }
+ if (!failedEmitters.isEmpty()) {
+ log.debug("心跳检测清理{}个失效SSE连接", failedEmitters.size());
+ failedEmitters.forEach(this::removeEmitter);
+ }
+ }
+
/**
* 容器关闭时主动断开所有 SSE 连接,避免阻塞应用停止
*/
diff --git a/src/main/resources/application-dev.yml b/src/main/resources/application-dev.yml
index a8ddba0c..f4e55e74 100644
--- a/src/main/resources/application-dev.yml
+++ b/src/main/resources/application-dev.yml
@@ -94,6 +94,7 @@ security:
- /v3/api-docs/**
- /webjars/**
- /favicon.ico
+ - /error
# 文件存储配置
oss:
diff --git a/src/main/resources/application-prod.yml b/src/main/resources/application-prod.yml
index d3d3fa06..d1bc7ff1 100644
--- a/src/main/resources/application-prod.yml
+++ b/src/main/resources/application-prod.yml
@@ -93,6 +93,7 @@ security:
- /v3/api-docs/**
- /webjars/**
- /favicon.ico
+ - /error
# 文件存储配置
oss: