Skip to content

Commit 8b1c6c0

Browse files
committed
后端手册完善
1 parent 7e739b7 commit 8b1c6c0

18 files changed

+702
-350
lines changed

src/.vuepress/sidebar.ts

+2-1
Original file line numberDiff line numberDiff line change
@@ -3,5 +3,6 @@ import { sidebar } from "vuepress-theme-hope";
33
export default sidebar({
44
"/vue3-element-admin/": "structure",
55
"/youlai-boot/": "structure",
6-
"/单体商城/": "structure",
6+
"/vue-uniapp-template/": "structure",
7+
"/youlai-mall/": "structure",
78
});

src/README.md

+6-6
Original file line numberDiff line numberDiff line change
@@ -27,29 +27,29 @@ features:
2727
- title: vue-uniapp-template
2828
details:
2929
<span style="font-weight:bold;color:#165DEF">移动端框架:</span>基于 Uni-App、Vue3 和 TypeScript 构建的灵活跨平台移动端模板,使用 VSCode 和 CLI 高效开发模式。
30-
link: /zh/guide/feature/comment.html
30+
link: /vue-uniapp-template/
3131
- title: youlai-nest
3232
details:
3333
<span style="font-weight:bold;color:#165DEF">Node后端框架:</span>基于 Node、Nest 和 TypeScript 构建的 RBAC 权限管理后端,前端全栈开发首选。
34-
link: /zh/guide/layout/
34+
link: /youlai-nest/
3535

3636
- title: youlai-cloud
3737
details:
3838
<span style="font-weight:bold;color:#00B42A">微服务框架:</span>基于 Java、Spring Boot 3、Spring Cloud & Alibaba、SAS 构建的微服务解决方案。
39-
link: /zh/guide/feature/page-info.html
39+
link: /youlai-cloud/
4040

4141
- title: youlai-mall
4242
details:
4343
<span style="font-weight:bold;color:#FF7D00">微服务商城:</span>基于 vue3-element-admin、youlai-cloud、uniapp-nutui-template 构建的微服务商城
44-
link: /zh/guide/feature/page-info.html
44+
link: /youlai-mall/
4545

4646
- title: mall-admin
4747
details: <span style="font-weight:bold;color:#FF7D00">商城管理前端:</span>基于 vue3-element-admin 模板框架开发的 youlai-mall 商城管理系统
48-
link: /zh/guide/blog/intro.html
48+
link: /mall-admin/
4949

5050
- title: mall-app
5151
details: <span style="font-weight:bold;color:#FF7D00">商城移动端:</span>youlai-mall 微信小程序/H5/Android/iOS 移动应用端。
52-
link: /zh/guide/interface/theme-color.html
52+
link: /mall-app/
5353

5454
copyright: false
5555
footer: MIT Licensed | Copyright © 2020-present 有来技术

src/vue-uniapp-template/README.md

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
---
2+
title: 移动端框架
3+
icon: palette
4+
dir:
5+
order: 1
6+
collapsible: false
7+
expanded: true
8+
link: true
9+
---

src/youlai-boot/3.开发指南/1.代码生成.md

+14-10
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,11 @@ tag:
99
---
1010

1111
:::tip
12-
以新增会员管理模块为例,来讲解如何生成前后端代码以及在项目中新增一个模块时自动生成菜单路由。
12+
本节将详细介绍两种代码生成方式:
13+
14+
**1. IDEA 插件生成** - 专注快速生成后端 CRUD 代码
15+
16+
**2. 项目代码生成** - 通过前端页面一键生成前后端完整模块
1317
:::
1418

1519
## IDEA 插件生成(后端代码)
@@ -19,40 +23,40 @@ tag:
1923

2024
在 IDEA 中依次点击 **File → Settings**(快捷键 **Ctrl + Alt + S**),打开设置面板,切换到 **Plugins** 选项卡,搜索 **MybatisX** 并安装插件。
2125

22-
![](https://i-blog.csdnimg.cn/img_convert/c32b3839c08f5c24cd3fcc31ca5291c2.png)
26+
![](https://www.youlai.tech/storage/blog/2025/02/23/c32b3839c08f5c24cd3fcc31ca5291c2.png)
2327

2428
### 自动代码生成
2529

2630
在 IDEA 右侧导航栏点击 **Database**,打开数据库配置面板,选择新增数据源。
2731

28-
![](https://i-blog.csdnimg.cn/img_convert/a2cad24770ce5d5adc4e47c31ad45505.png)
32+
![](https://www.youlai.tech/storage/blog/2025/02/23/a2cad24770ce5d5adc4e47c31ad45505.png)
2933

3034
输入数据库的 **主机地址****用户名****密码**,测试连接成功后点击 `OK` 保存。
31-
![](https://i-blog.csdnimg.cn/direct/6e8259d52a2041a4b573dfd15dc54c15.png)
3235

33-
36+
![](https://www.youlai.tech/storage/blog/2025/02/23/6e8259d52a2041a4b573dfd15dc54c15.png)
3437

38+
3539
配置完数据源后,展开数据库中的表,右击 **sys_user** 表,选择 **MybatisX-Generator** 打开代码生成面板。
3640

37-
![](https://i-blog.csdnimg.cn/direct/4dd6c3ca2daf4eefbca0a94d624b8d5e.png)
41+
![](https://www.youlai.tech/storage/blog/2025/02/23/4dd6c3ca2daf4eefbca0a94d624b8d5e.png)
3842

3943

4044
设置代码生成的目标路径,并选择 **Mybatis-Plus 3 + Lombok** 代码风格。
4145

42-
![](https://i-blog.csdnimg.cn/direct/4609cbba1ca74fb784a3c30a36ffc9cf.png)
46+
![](https://www.youlai.tech/storage/blog/2025/02/23/4609cbba1ca74fb784a3c30a36ffc9cf.png)
4347

4448

45-
![](https://i-blog.csdnimg.cn/img_convert/3804dea39c8abe0acf193093d9eecd1d.png)
49+
![](https://www.youlai.tech/storage/blog/2025/02/23/3804dea39c8abe0acf193093d9eecd1d.png)
4650

4751
点击 `Finish` 生成,自动生成相关代码。
4852

49-
![](https://i-blog.csdnimg.cn/img_convert/7e4f7cf07c1aedf8303e2c77e78283a9.png)
53+
![](https://www.youlai.tech/storage/blog/2025/02/23/7e4f7cf07c1aedf8303e2c77e78283a9.png)
5054

5155
MybatisX 生成的代码存在以下问题:
5256

5357
- `SysUserMapper.java` 文件未标注 `@Mapper` 注解,导致无法被 Spring Boot 识别为 Mybatis 的 Mapper 接口。如果已配置 `@MapperScan`,可以省略此注解,但最简单的方法是直接在 `SysUserMapper.java` 文件中添加 `@Mapper` 注解。注意避免导入错误的包。
5458

55-
![](https://i-blog.csdnimg.cn/img_convert/a35123dfa197213e06941541a716f76b.png)
59+
![](https://www.youlai.tech/storage/blog/2025/02/23/a35123dfa197213e06941541a716f76b.png)
5660

5761

5862
## 项目代码生成(前后端代码)
Original file line numberDiff line numberDiff line change
@@ -1,32 +1,39 @@
11
---
22
title: 修改包名
33
icon: list
4-
order: 3
4+
order: 2
55
category:
66
- 开发指南
77
tag:
88
- 修改包名
99
---
10+
1011
:::tip
11-
在项目中,如果需要修改默认的包名,需要做以下改动
12+
如果需要修改项目名,请按以下步骤同步调整配置(示例:将 com.youlai.boot 改为 com.wuhui.boot)
1213
:::
1314

14-
默认包名为 `com.youlai.boot`,如需修改为 `com.wuhui.boot`,需要做以下改动:
15+
## 配置修改清单
16+
17+
### 启动类包路径
18+
19+
重命名启动类文件: `YoulaiBootApplication.java``WuhuiBootApplication.java`
20+
21+
### 应用标识
1522

16-
- 修改启动类名称
23+
- application.yml 修改:
1724

18-
将启动类从 `YoulaiBootApplication` 改为 `WuhuiBootApplication`
25+
`application.yml` 中将 `spring.application.name` 的值从 `youlai-boot` 修改为 `wuhui-boot`
1926

20-
- 修改应用名称
27+
- pom.xml 修改:
2128

22-
`application.yml` 中将 `spring.application.name` 的值从 `youlai-boot` 修改为 `wuhui-boot`;在 `pom.xml` 中将 `<groupId>` 值从 `com.youlai` 改为 `com.wuhui`
29+
`pom.xml` 中将 `<groupId>` 值从 `com.youlai` 改为 `com.wuhui`
2330

24-
- 修改接口文档包路径,否则接口文档不显示接口描述
31+
### 接口文档配置
2532

26-
`application-*.yml` 修改接口文档扫描包路径
33+
`application-*.yml` 修改接口文档扫描包路径 , 否则接口文档不显示接口描述
2734

28-
![](https://i-blog.csdnimg.cn/img_convert/8f6c053061051f5c40733785c4512d5e.png)
35+
![](https://www.youlai.tech/storage/blog/2025/02/23/8f6c053061051f5c40733785c4512d5e.png)
2936

30-
- 代码生成的项目名称
37+
### 代码生成配置
3138

3239
`codegen.yml` 里修改后端项目名称 `codegen.backendAppName` 替换 youlai-boot 为 wuhui-boot
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,82 @@
1+
---
2+
title: 数据权限
3+
icon: list
4+
order: 3
5+
category:
6+
- 开发指南
7+
tag:
8+
- 数据权限
9+
---
10+
11+
:::tip
12+
数据权限是指用户在系统中对数据的访问权限。通过数据权限,可以实现对用户访问数据的控制,保证数据的安全性。
13+
:::
14+
15+
## 实现原理
16+
17+
通过自定义拦截器实现 `DataPermissionHandler` 接口。在 youlai-boot 中,`MyDataPermissionHandler` 是其具体实现类,用于在 SQL 执行前动态拼接权限过滤条件。
18+
处理逻辑如下:
19+
20+
- 获取用户权限范围(如部门或用户)。
21+
- 动态生成筛选条件:如部门及以下的 `dept_id IN (...)` 或个人创建的 `create_by = ...`
22+
- 将条件追加到原始 SQL 的 `WHERE` 子句。
23+
24+
## 使用示例
25+
26+
在数据持久层的方法中,如果需要实现数据权限控制,可以直接在方法上添加 `@DataPermission` 注解。
27+
28+
**UserMapper.java**
29+
30+
```java
31+
@Mapper
32+
public interface UserMapper {
33+
34+
@DataPermission(
35+
deptAlias = "u", // 部门字段的表别名,用于标记 SQL 中部门字段的来源表
36+
deptIdColumnName = "dept_id", // 部门字段的列名,默认为 dept_id
37+
userAlias = "u", // 用户字段的表别名,用于标记 SQL 中用户字段的来源表
38+
userIdColumnName = "create_by" // 用户字段的列名,默认为 create_by
39+
)
40+
Page<UserBO> getUserPage(Page<UserBO> page, UserPageQuery queryParams);
41+
}
42+
```
43+
44+
**UserMapper.xml**
45+
46+
```xml
47+
<select id="getUserPage">
48+
SELECT
49+
u.id,
50+
u.username,
51+
u.nickname,
52+
u.dept_id
53+
FROM
54+
sys_user u
55+
WHERE
56+
u.is_deleted = 0
57+
</select>
58+
```
59+
60+
动态 SQL 示例:
61+
62+
- **权限范围:部门及以下**
63+
64+
```sql
65+
SELECT u.id, u.username, u.nickname, u.dept_id
66+
FROM sys_user u
67+
WHERE u.is_deleted = 0
68+
AND u.dept_id IN (SELECT id FROM sys_dept WHERE id = 3 OR FIND_IN_SET(3, tree_path));
69+
```
70+
71+
其中`AND u.dept_id IN (SELECT id FROM sys_dept WHERE id = 3 OR FIND_IN_SET(3, tree_path))``MyDataPermissionHandler` 根据用户权限为“部门及以下”动态追加的筛选条件。
72+
73+
- **权限范围:本人创建**
74+
75+
```sql
76+
SELECT u.id, u.username, u.nickname, u.dept_id
77+
FROM sys_user u
78+
WHERE u.is_deleted = 0
79+
AND u.create_by = 2;
80+
```
81+
82+
其中:`AND u.create_by = 2``MyDataPermissionHandler` 根据用户权限为“本人创建”动态追加的筛选条件。

src/youlai-boot/3.开发指南/3.认证鉴权.md

-58
This file was deleted.

src/youlai-boot/3.开发指南/4.数据权限.md

-71
This file was deleted.

0 commit comments

Comments
 (0)