153 lines
4.0 KiB
Markdown
153 lines
4.0 KiB
Markdown
<!--
|
||
* @Author: Mm
|
||
* @Date: 2025-02-20 09:55:11
|
||
* @LastEditors: Mm
|
||
* @LastEditTime: 2025-04-10 09:55:22
|
||
* 不写bug的程序员不是一个好程序员!
|
||
-->
|
||
|
||
## 提示
|
||
|
||
该仓库使用vben最新版本v5开发
|
||
|
||
v5版本采用分仓(包)目录结构, 具体开发路径为: `根目录/apps/web-antd`
|
||
|
||
目前对应后端版本: **分布式5.3.0/微服务2.2.2**
|
||
|
||
V1.1.0版本已支持离线图标
|
||
|
||
|
||
## 简介
|
||
|
||
基于 [vben5 & ant-design-vue](https://github.com/vbenjs/vue-vben-admin) 的 RuoYi-Vue-Plus 前端项目
|
||
|
||
| 组件/框架 | 版本 |
|
||
| :------------- | :----- |
|
||
| vben | 5.5.3 |
|
||
| ant-design-vue | 4.2.6 |
|
||
| vue | 3.5.13 |
|
||
|
||
对应后端项目: **(分布式 5.X 分支 微服务 2.分支)**
|
||
|
||
分布式 [RuoYi-Vue-Plus](https://gitee.com/dromara/RuoYi-Vue-Plus/tree/5.X/)
|
||
|
||
微服务 [RuoYi-Cloud-Plus](https://gitee.com/dromara/RuoYi-Cloud-Plus/tree/2.X/)
|
||
|
||
|
||
## 文档
|
||
|
||
[Vben V5 文档地址](https://doc.vben.pro/)
|
||
|
||
|
||
## 安装使用
|
||
|
||
前置准备环境(只能用pnpm)
|
||
|
||
```json
|
||
"packageManager": "pnpm",
|
||
"engines": {
|
||
"node": ">=20.15.0",
|
||
"pnpm": "latest"
|
||
},
|
||
```
|
||
|
||
- 获取项目代码
|
||
|
||
```bash
|
||
git clone http://git.helou.vip:8088/ruansi/Vben5-Base.git
|
||
```
|
||
|
||
- 安装依赖
|
||
|
||
```bash
|
||
cd Vben5-Base
|
||
|
||
pnpm install
|
||
```
|
||
|
||
- 菜单图标替换
|
||
|
||
参考 [菜单图标替换](https://dapdap.top/guide/quick-start.html#%E8%8F%9C%E5%8D%95%E5%9B%BE%E6%A0%87%E5%AF%BC%E5%85%A5)
|
||
|
||
|
||
- 关于一些监控的地址配置(微服务版本可以跳过这一小节)
|
||
|
||
使用[RuoYi-Vue-Plus](https://gitee.com/dromara/RuoYi-Vue-Plus/tree/5.X/)注意 `已经去除 admin/snailjob 的.env 配置` 可自行修改 有两种方式
|
||
|
||
1. 修改源码`/views/monitor/admin` `views/monitor/snailjob`
|
||
|
||
```html
|
||
<!-- 修改地址 -->
|
||
<template>
|
||
<iframe
|
||
class="size-full"
|
||
src="http://localhost:9090/admin/applications"
|
||
></iframe>
|
||
</template>
|
||
```
|
||
|
||
2. **推荐** 使用菜单自行配置 (跟 cloud 版本打开方式一致)
|
||
|
||

|
||
|
||
使用内嵌 iframe 方式需要解决跨域问题 可参考[nginx.conf](https://gitee.com/dromara/RuoYi-Vue-Plus/blob/5.X/script/docker/nginx/conf/nginx.conf#LC87)配置
|
||
|
||
- 修改.env.development 配置文件
|
||
- **注意 RSA 公私钥一定要修改和后端匹配**
|
||
- RSA 公私钥为两对 `前端请求加密-后端解密是一对` `后端响应加密 前端解密是一对`
|
||
|
||
```properties
|
||
# 端口号
|
||
VITE_PORT=5666
|
||
# 打包路径
|
||
VITE_BASE=/
|
||
# 是否开启 Nitro Mock服务,true 为开启,false 为关闭
|
||
VITE_NITRO_MOCK=false
|
||
# 是否打开 devtools,true 为打开,false 为关闭
|
||
VITE_DEVTOOLS=false
|
||
# 是否注入全局loading
|
||
VITE_INJECT_APP_LOADING=true
|
||
|
||
# 后台请求路径 具体在vite.config.mts配置代理
|
||
VITE_GLOB_API_URL=/api
|
||
# 全局加密开关(即开启了加解密功能才会生效 不是全部接口加密 需要和后端对应)
|
||
VITE_GLOB_ENABLE_ENCRYPT=true
|
||
# RSA公钥 请求加密使用 注意这两个是两对RSA公私钥 请求加密-后端解密是一对 响应解密-后端加密是一对
|
||
VITE_GLOB_RSA_PUBLIC_KEY=
|
||
# RSA私钥 响应解密使用 注意这两个是两对RSA公私钥 请求加密-后端解密是一对 响应解密-后端加密是一对
|
||
VITE_GLOB_RSA_PRIVATE_KEY=
|
||
# 客户端id
|
||
VITE_GLOB_APP_CLIENT_ID=e5cd7e4891bf95d1d19206ce24a7b32e
|
||
# 开启WEBSOCKET
|
||
VITE_GLOB_WEBSOCKET_ENABLE=false
|
||
```
|
||
|
||
- 运行
|
||
|
||
```bash
|
||
pnpm dev:antd
|
||
```
|
||
|
||
- 打包
|
||
|
||
```bash
|
||
pnpm build:antd
|
||
```
|
||
|
||
## 这是一个特性 而不是一个bug!
|
||
|
||
1. 菜单管理可分配 但只有`admin`/`superadmin`角色能访问 其他角色访问会到403页面
|
||
2. 租户相关菜单可分配 但只有`superadmin`角色能访问 其他角色访问会到403页面
|
||
3. 分配的租户管理员无法修改自己的角色的菜单(即管理员角色的菜单) 防止自己把自己权限弄没了
|
||
|
||
|
||
|
||
## 浏览器支持
|
||
|
||
最低适配应该为`Chrome 88+`以上浏览器 详见 [css - where](https://developer.mozilla.org/en-US/docs/Web/CSS/:where#browser_compatibility)
|
||
|
||
本地开发推荐使用`Chrome` 最新版本浏览器
|
||
|
||
支持现代浏览器, 不支持 IE
|
||
|