feat: mcp支持,模块重构

This commit is contained in:
ageer
2025-04-12 15:18:16 +08:00
parent 0dc6262b39
commit 4b53939002
225 changed files with 11937 additions and 163 deletions

125
ruoyi-admin/pom.xml Normal file
View File

@@ -0,0 +1,125 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>ruoyi-ai</artifactId>
<groupId>org.ruoyi</groupId>
<version>${revision}</version>
<relativePath>../pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<packaging>jar</packaging>
<artifactId>ruoyi-admin</artifactId>
<description>
web服务入口
</description>
<dependencies>
<!-- Mysql驱动包 -->
<dependency>
<groupId>com.mysql</groupId>
<artifactId>mysql-connector-j</artifactId>
</dependency>
<!-- Oracle -->
<dependency>
<groupId>com.oracle.database.jdbc</groupId>
<artifactId>ojdbc8</artifactId>
</dependency>
<!-- PostgreSql -->
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
</dependency>
<!-- SqlServer -->
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.ruoyi</groupId>
<artifactId>ruoyi-common-doc</artifactId>
</dependency>
<dependency>
<groupId>org.ruoyi</groupId>
<artifactId>ruoyi-system</artifactId>
</dependency>
<dependency>
<groupId>org.ruoyi</groupId>
<artifactId>ruoyi-fusion</artifactId>
</dependency>
<dependency>
<groupId>org.ruoyi</groupId>
<artifactId>ruoyi-knowledge</artifactId>
</dependency>
<!-- demo模块 -->
<dependency>
<groupId>org.ruoyi</groupId>
<artifactId>ruoyi-demo</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- 添加thumbnailator依赖 -->
<dependency>
<groupId>net.coobird</groupId>
<artifactId>thumbnailator</artifactId>
<version>0.4.11</version>
</dependency>
<dependency>
<groupId>io.github.ollama4j</groupId>
<artifactId>ollama4j</artifactId>
<version>1.0.79</version>
<scope>compile</scope>
</dependency>
</dependencies>
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>${maven-jar-plugin.version}</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>${maven-war-plugin.version}</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
<warName>${project.artifactId}</warName>
</configuration>
</plugin>
</plugins>
</build>
</project>

View File

@@ -1,4 +1,4 @@
package org.ruoyi.system;
package org.ruoyi;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

View File

@@ -1,4 +1,4 @@
package org.ruoyi.system;
package org.ruoyi;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;

View File

@@ -1,12 +1,14 @@
package org.ruoyi.system.controller.system;
package org.ruoyi.controller;
import cn.dev33.satoken.annotation.SaIgnore;
import cn.hutool.core.collection.CollUtil;
import jakarta.servlet.http.HttpServletRequest;
import lombok.RequiredArgsConstructor;
import org.ruoyi.common.core.constant.Constants;
import org.ruoyi.common.core.domain.R;
import org.ruoyi.common.core.domain.model.*;
import org.ruoyi.common.core.domain.model.EmailLoginBody;
import org.ruoyi.common.core.domain.model.LoginBody;
import org.ruoyi.common.core.domain.model.RegisterBody;
import org.ruoyi.common.core.domain.model.SmsLoginBody;
import org.ruoyi.common.core.domain.model.VisitorLoginBody;
import org.ruoyi.common.core.utils.MapstructUtils;
import org.ruoyi.common.core.utils.StreamUtils;
import org.ruoyi.common.core.utils.StringUtils;
@@ -14,12 +16,16 @@ import org.ruoyi.common.satoken.utils.LoginHelper;
import org.ruoyi.common.tenant.helper.TenantHelper;
import org.ruoyi.system.domain.bo.SysTenantBo;
import org.ruoyi.system.domain.vo.LoginTenantVo;
import org.ruoyi.system.domain.vo.LoginVo;
import org.ruoyi.system.domain.vo.SysTenantVo;
import org.ruoyi.system.domain.vo.TenantListVo;
import org.ruoyi.system.service.ISysTenantService;
import org.ruoyi.system.service.SysLoginService;
import org.ruoyi.system.service.SysRegisterService;
import org.ruoyi.system.domain.vo.LoginVo;
import jakarta.servlet.http.HttpServletRequest;
import lombok.RequiredArgsConstructor;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
@@ -42,15 +48,6 @@ public class AuthController {
private final SysRegisterService registerService;
private final ISysTenantService tenantService;
// @PostMapping("/xcxLogin")
// public R<LoginVo> login(@Validated @RequestBody String xcxCode) throws WxErrorException {
//
// String openidFromCode = loginService.getOpenidFromCode((String) JSONUtil.parseObj(xcxCode).get("xcxCode"));
// LoginVo loginVo = loginService.mpLogin(openidFromCode);
// return R.ok(loginVo);
// }
/**
* 登录方法
*
@@ -67,7 +64,6 @@ public class AuthController {
body.getUsername(), body.getPassword(),
body.getCode(), body.getUuid());
loginVo.setToken(token);
loginVo.setAccess_token(token);
loginVo.setUserInfo(LoginHelper.getLoginUser());
return R.ok(loginVo);
}
@@ -89,7 +85,6 @@ public class AuthController {
/**
* 访客登录
*
* @param loginBody 登录信息
* @return token信息
*/
@@ -128,7 +123,7 @@ public class AuthController {
*/
@PostMapping("/register")
public R<Void> register(@Validated @RequestBody RegisterBody user, HttpServletRequest request) {
String domainName = request.getServerName();
String domainName = request.getServerName();
user.setDomainName(domainName);
registerService.register(user);
return R.ok();

View File

@@ -1,14 +1,10 @@
package org.ruoyi.system.controller.system;
package org.ruoyi.controller;
import cn.dev33.satoken.annotation.SaIgnore;
import cn.hutool.captcha.AbstractCaptcha;
import cn.hutool.captcha.generator.CodeGenerator;
import cn.hutool.core.util.IdUtil;
import cn.hutool.core.util.RandomUtil;
import jakarta.validation.Valid;
import jakarta.validation.constraints.NotBlank;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.ruoyi.common.core.constant.Constants;
import org.ruoyi.common.core.constant.GlobalConstants;
import org.ruoyi.common.core.domain.R;
@@ -26,6 +22,10 @@ import org.ruoyi.common.web.config.properties.CaptchaProperties;
import org.ruoyi.common.web.enums.CaptchaType;
import org.ruoyi.system.domain.request.EmailRequest;
import org.ruoyi.system.domain.vo.CaptchaVo;
import jakarta.validation.Valid;
import jakarta.validation.constraints.NotBlank;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.expression.Expression;
import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
@@ -36,8 +36,7 @@ import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import java.time.Duration;
import java.util.HashMap;
import java.util.Map;
import java.util.*;
/**
* 验证码操作处理
@@ -95,6 +94,7 @@ public class CaptchaController {
String suffix = configService.getConfigValue("mail", "suffix");
String prompt = configService.getConfigValue("mail", "prompt");
if(StringUtils.isNotEmpty(suffix)){
// 动态的域名列表
String[] invalidDomains = suffix.split(",");
for (String domain : invalidDomains) {
if (emailRequest.getUsername().endsWith(domain)) {
@@ -107,7 +107,7 @@ public class CaptchaController {
String mailTitle = configService.getConfigValue("mail", "mailTitle");
String replacedModel = model.replace("{code}", code);
try {
MailUtils.sendHtml(emailRequest.getUsername(), mailTitle, replacedModel);
MailUtils.sendHtml(emailRequest.getUsername(), mailTitle, replacedModel);
} catch (Exception e) {
log.error("邮箱验证码发送异常 => {}", e.getMessage());
return R.fail(e.getMessage());

View File

@@ -1,9 +1,9 @@
package org.ruoyi.system.controller.system;
package org.ruoyi.controller;
import cn.dev33.satoken.annotation.SaIgnore;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* 首页
@@ -12,7 +12,7 @@ import org.springframework.web.bind.annotation.RestController;
*/
@SaIgnore
@RequiredArgsConstructor
@RestController
@Controller
public class IndexController {
/**
@@ -20,7 +20,17 @@ public class IndexController {
*/
@GetMapping("/")
public String index() {
return "RuoYi-AI 启动成功";
return "index.html";
}
@GetMapping("/success")
public String success(){
return "paySuccess.html";
}
@GetMapping("/cancel")
public String cancel(){
return "cancel";
}
}

View File

@@ -25,10 +25,9 @@ spring:
master:
type: ${spring.datasource.type}
driverClassName: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://43.139.70.230:3306/ruoyi-ai?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
username: ruoyi-ai
password: ruoyi-ai
url: jdbc:mysql://43.139.70.230:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
username: ry-vue
password: xx
hikari:
# 最大连接池数量
@@ -97,3 +96,23 @@ sms:
signName: 测试
# 腾讯专用
sdkAppId:
spring:
ai:
openai:
api-key: sk-xX
base-url: https://api.pandarobot.chat
ollama:
base-url: http://localhost:11434
init:
pull-model-strategy: always
timeout: 60s
max-retries: 1
mcp:
client:
enabled: true
name: call-mcp-server
sse:
connections:
server1:
url: http://127.0.0.1:8080

View File

@@ -318,22 +318,5 @@ wechat:
token: ''
aesKey: ''
# spring ai配置
spring:
ai:
openai:
api-key: sk-xx
base-url: https://api.pandarobot.chat/
mcp:
client:
enabled: true
name: call-mcp-server
sse:
connections:
server1:
url: http://127.0.0.1:8080
ollama:
init:
pull-model-strategy: always
timeout: 60s
max-retries: 1

View File

@@ -0,0 +1,46 @@
######################################################################
# Build Tools
.gradle
/build/
!gradle/wrapper/gradle-wrapper.jar
target/
!.mvn/wrapper/maven-wrapper.jar
######################################################################
# IDE
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### JRebel ###
rebel.xml
### NetBeans ###
nbproject/private/
build/*
nbbuild/
nbdist/
.nb-gradle/
######################################################################
# Others
*.log
*.xml.versionsBackup
*.swp
!*/build/*.java
!*/build/*.html
!*/build/*.xml

View File

@@ -0,0 +1 @@
plus-doc.dromara.org

View File

@@ -0,0 +1,74 @@
# 框架介绍
- - -
- `RuoYi-Vue-Plus` 分布式集群框架 [文档跳转](/ruoyi-vue-plus/home.md)
- `RuoYi-Cloud-Plus` 微服务框架 [文档跳转](/ruoyi-cloud-plus/home.md)
- `plus-ui` 统一 Vue3 前端项目 [文档跳转](/plus-ui/home.md)
- `plus-doc` 统一文档项目
## 特别赞助
<a href="https://gitee.com/dromara/MaxKey"><img src="https://foruda.gitee.com/images/1700187453544179968/7342304a_1766278.png" width="400px" height="100px"></a>
<a href="http://ccflow.org/?frm=ryPlus"><img src="https://foruda.gitee.com/images/1704162419429172656/d0521e59_1766278.png" width="400px" height="100px"></a>
<br>
<a href="http://www.shuduokeji.com"><img src="https://foruda.gitee.com/images/1705569347386939952/3f187980_1766278.jpeg" width="400px" height="100px"></a>
<a href="https://www.jnpfsoft.com/index.html?from=plus-doc"><img src="https://foruda.gitee.com/images/1711681233267310022/2ffbcff2_1766278.png" width="400px" height="100px"></a>
<br>
<a href="https://item.jd.com/13928958.html?from=plus-doc"><img src="https://foruda.gitee.com/images/1723791569938403230/769e98da_1766278.jpeg" width="400px" height="100px"></a>
[如何成为赞助商 加群联系作者详谈](/common/add_group.md)
## 代码地址
| 介绍 | 项目名 | 项目地址 | 注意事项 |
|------------|:-----------------|------------------------------------------------------------------------------------------------------------------------|----------------------------|
| 🔥 分布式集群框架 | RuoYi-Vue-Plus | - [Gitee](https://gitee.com/dromara/RuoYi-Vue-Plus)<br> - [GitHub](https://github.com/dromara/RuoYi-Vue-Plus) | 重写RuoYi-Vue全方位升级(不兼容原框架) |
| 🔥 微服务框架 | RuoYi-Cloud-Plus | - [Gitee](https://gitee.com/dromara/RuoYi-Cloud-Plus)<br>- [GitHub](https://github.com/dromara/RuoYi-Cloud-Plus) | 重写RuoYi-Cloud全方位升级(不兼容原框架) |
| 🔥 统一前端项目 | plus-ui | - [Gitee](https://gitee.com/JavaLionLi/plus-ui)<br>- [GitHub](https://github.com/JavaLionLi/plus-ui) | Vue与Cloud项目通用前端 |
| 🔥 统一文档项目 | plus-doc | - [Gitee](https://gitee.com/dromara/plus-doc)<br>- [GitHub](https://github.com/dromara/plus-doc) | 通用文档 |
## 业务功能
| 功能 | 介绍 |
|-------|---------------------------------------|
| 租户管理 | 配置系统租户,支持 SaaS 场景下的多租户功能。 |
| 用户管理 | 用户是系统操作者,该功能主要完成系统用户配置。 |
| 部门管理 | 配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。 |
| 岗位管理 | 配置系统用户所属担任职务。 |
| 菜单管理 | 配置系统菜单,操作权限,按钮权限标识等。 |
| 角色管理 | 角色菜单权限分配、设置角色按机构进行数据范围权限划分。 |
| 字典管理 | 对系统中经常使用的一些较为固定的数据进行维护。 |
| 参数管理 | 对系统动态配置常用参数。 |
| 通知公告 | 系统通知公告信息发布维护。 |
| 操作日志 | 系统正常操作日志记录和查询;系统异常信息日志记录和查询。 |
| 登录日志 | 系统登录日志记录查询包含登录异常。 |
| 文件管理 | 系统文件上传、下载等管理。 |
| 定时任务 | 在线(添加、修改、删除)任务调度包含执行结果日志。 |
| 代码生成 | 前后端代码的生成java、html、xml、sql支持CRUD下载 。 |
| 系统接口 | 根据业务代码自动生成相关的api接口文档。 |
| 服务监控 | 监视集群系统CPU、内存、磁盘、堆栈、在线日志、Spring相关配置等。 |
| 缓存监控 | 对系统的缓存信息查询,命令统计等。 |
| 在线构建器 | 拖动表单元素生成相应的HTML代码。 |
| 使用案例 | 系统的一些功能案例 |
## 关注作者
作者博客: [https://lionli.blog.csdn.net/?type=blog](https://lionli.blog.csdn.net/?type=blog)
公众号: **<狮子领域 程序圈>**
<br>
![输入图片说明](https://foruda.gitee.com/images/1678975769377570440/507062df_1766278.png "屏幕截图")
## 捐献作者
**作者为兼职做开源,平时还需要工作,如果帮到了您可以请作者吃个盒饭**
<br>
<img src="https://foruda.gitee.com/images/1725259663554875162/bd86a165_1766278.png" width="300px" height="450px" /><img src="https://foruda.gitee.com/images/1725259708005620620/22833e19_1766278.jpeg" width="300px" height="450px" />
## Dromara 全家福
社区仓库地址: [dromara开源社区](https://gitee.com/organizations/dromara/projects)
![输入图片说明](https://foruda.gitee.com/images/1706071866226295002/68cffcf6_1766278.png "屏幕截图")

View File

@@ -0,0 +1,32 @@
<!-- _coverpage.md -->
<html>
<img src="./static/image/logo2.png" width="260px" height="260px">
<div style="display: flex; align-content:center; justify-content: center;">
<div >
<div style="font-weight: bold; font-size: 40px;">百搭AI</div>
<!-- <div style="font-weight: bold; font-size: 40px;margin-bottom: 30px;">多租户权限管理系统</div> -->
[![码云Gitee](https://gitee.com/ageerle/ruoyi-ai/badge/star.svg?theme=blue)](https://gitee.com/ageerle/ruoyi-ai)
[![GitHub](https://img.shields.io/github/stars/ageerle/ruoyi-ai.svg?style=social&label=Stars)](https://github.com/dromara/RuoYi-Vue-Plus)
[![License](https://img.shields.io/badge/License-MIT-blue.svg)](https://gitee.com/ageerle/ruoyi-ai/blob/master/LICENSE)
<br>
[![ruoyi-ai](https://img.shields.io/badge/ruoyi-ai-5.2.2-success.svg)](https://gitee.com/ageerle/ruoyi-ai)
[![Spring Boot](https://img.shields.io/badge/Spring%20Boot-3.2-blue.svg)]()
</div>
<div>
</div>
</div>
</html>
> 百搭AI是一个整合了多种大语言模型API的开源平台实现了AI对话、绘图、声音克隆和私有知识库等功能。
>
> 平台配备管理后台支持微信支付、微信公众号、微信多开、Stripe国际支付和百度文本审核等运营功能。
>
> 项目采用Java+Vue+Vben5技术栈构建遵循MIT License允许二次开发并用于商业销售。
Copyright © 2023-2024 版权所有ageerle@163.com 备案号:<a href="https://beian.miit.gov.cn/">鄂ICP备2023007672号</a>
[开始使用 Let's Go](/README.md)

View File

@@ -0,0 +1,2 @@
<!-- _footer.md 页脚配置 -->
对文档有疑问?欢迎您帮助我们 [完善此文档](https://gitee.com/JavaLionLi/plus-doc)

View File

@@ -0,0 +1,9 @@
<!-- _navbar.md -->
* [文档导航](/README.md)
* [Vue版本](/ruoyi-vue-plus/home.md)
* [Cloud版本](/ruoyi-cloud-plus/home.md)
* [前端文档](/plus-ui/home.md)
* [常见问题](/questions/lombok.md)
* [视频教程](/common/video.md)
* [演示系统](/common/demo_system.md)

View File

@@ -0,0 +1,16 @@
<!-- _sidebar.md -->
- **特别赞助**
- [![输入图片说明](https://foruda.gitee.com/images/1704162419429172656/d0521e59_1766278.png "2024-01-02=>2028-01-02")](http://ccflow.org/?frm=ryPlus)
- [![输入图片说明](https://foruda.gitee.com/images/1705569347386939952/3f187980_1766278.jpeg "2024-01-18=>2025-01-18")](http://www.shuduokeji.com)
- [![输入图片说明](https://foruda.gitee.com/images/1711681233267310022/2ffbcff2_1766278.png "2024-03-29=>2025-03-29")](https://www.jnpfsoft.com/index.html?from=plus-doc)
- **开始**
- [框架介绍](/README.md)
- [演示系统](/common/demo_system.md)
- [官方视频教程](/common/video.md)
- [粉丝专栏](/common/column.md)
- [参与贡献项目](/common/contribution.md)
- [如何提交PR](/common/pr.md)
- [如何加群](/common/add_group.md)
- [使用者登记](/common/user_register.md)
- [黑名单](/common/blacklist.md)

View File

@@ -0,0 +1,27 @@
# 加群方式
- - -
### 交流群(不提供任何问题解答 纯交流)
**加 <小助手> 微信备注 <加群>**<br>
**视频课程咨询或其他问题咨询请查看下方信息(小助手是机器人)**
<img src="https://foruda.gitee.com/images/1680762410689884638/60b546ca_1766278.png" width="300" height="300">
### VIP群(付费加群 提供问题解答、技术支持、技术分享)
首先感谢 `RuoYi` 提供分享开源 框架基于 `RuoYi` 重写大部分功能实现<br>
项目代码、文档 均开源免费可商用 遵循开源协议在项目中保留开源协议文件即可<br>
VIP群是作者提供的私人服务 不代表着项目收费
> 问问题等于做习题 听作者解答问题等于习题讲解<br>
> 一个人接触的问题有限 一群人接触的问题无限 早进群早接触更多的问题(每天99+)<br>
> 承诺: 看见必回复 让你感受作者有多话痨<br>
两种途径:
1. 购买官方视频进群 [官方视频](/common/video.md)
2. 扫描下方二维码付款进群(无视频)
支付后申请加群即可 QQ群号 : **<637757165>**<br>
**加群扫码**<br>
<img src="https://foruda.gitee.com/images/1725259839682556495/2897bc86_1766278.png" width="300px" height="450px" /><img src="https://foruda.gitee.com/images/1725259806547656944/f870a5c7_1766278.jpeg" width="300px" height="450px" />

View File

@@ -0,0 +1,7 @@
# 黑名单
- - -
地址: https://github.com/QNAV/RuoYi-X-Plus
<br>
上榜缘由 使用本框架二次开源并未有任何声明与标注 将所有代码的作者名全都改成了自己 剽窃本框架代码

View File

@@ -0,0 +1,18 @@
# 粉丝专栏
- - -
**由上到下 从易到难**
> 粉丝整理 欢迎投稿
| 作者 | 文档地址 | 说明 |
|---------------|---------------------------------------------------------------|--------------------|
| 抓蛙师 | https://www.bilibili.com/video/BV1TG41157Ef/ | 学会问问题(小白必看) |
| 抓蛙师 | https://www.bilibili.com/video/BV1mr4y1j75M | Vue框架基础视频专栏(新人必看) |
| 抓蛙师 | https://www.bilibili.com/video/BV1Na411u7eC | Vue框架改造视频专栏(新人必看) |
| 抓蛙师 | https://www.bilibili.com/video/BV1te4y1D7hi | 小程序鉴权与uniapp联动 |
| 抓蛙师 | https://www.bilibili.com/video/BV1zt4y137UP | 公众号集成 |
| mayuanfei | https://note.youdao.com/s/XpvKnxAb | 入门专栏(新人必看) |
| 程序猿一枚_ | https://blog.csdn.net/zhaozhiqiang1981/category_12221291.html | 玩转RuoYi-Cloud-Plus |
| 程序猿一枚_ | https://www.bilibili.com/video/BV1yA411r7ji/ | Cloud环境搭建以及进阶开发 |
| MichelleChung | https://blog.csdn.net/michelle_zhong/category_11109741.html | 源码解析专栏(进阶必看) |
| MichelleChung | https://blog.csdn.net/michelle_zhong/category_12058476.html | Cloud源码解析专栏 |

View File

@@ -0,0 +1,69 @@
# 参与贡献的方式
- - -
参与贡献开源的方式有很多种 听作者来介绍
## 为开源项目点一个Star
> Star的多少关系到项目能否被更多人看到
<br>
同时Star也是作者前进的动力(作者每天都在盯着Star 涨了会开心 跌了会失落)
<br>
<br>
> 大家在寻找开源项目的时候, 大多数情况也是会先看Star比较多的项目
<br>
所以请给您觉得好的开源项目点一个小小的Star, 让好的项目能够被更多人看到
<br>
![输入图片说明](https://foruda.gitee.com/images/1678934493115487351/0c45121e_1766278.png "屏幕截图")
<br>
<font size="4">Vue版本: [Gitee我要点Star](https://gitee.com/dromara/RuoYi-Vue-Plus/stargazers) [Github我要点Star](https://github.com/dromara/RuoYi-Vue-Plus)</font>
<br>
<font size="4">Cloud版本: [Gitee我要点Star](https://gitee.com/dromara/RuoYi-Cloud-Plus/stargazers) [Github我要点Star](https://github.com/dromara/RuoYi-Cloud-Plus)</font>
## 为社区处理问题
> Issue是社区的交流地 大家会在这里提出自己的问题 或者是项目的功能异常
> 提问的规范在Issue的模板里已经写好了 按照模板填写有助于作者或者其他社区人员快速有效的回答问题
![输入图片说明](https://foruda.gitee.com/images/1678935068341532603/4b9d7af9_1766278.png "屏幕截图")
> 为提出问题的小伙伴答疑 可以有效降的帮助别人<br>
> 而且可以降低社区人员的精力分散 使精力全部投入到项目设计研发中
![输入图片说明](https://foruda.gitee.com/images/1678935380481365514/dddc9ce9_1766278.png "屏幕截图")
## 改进社区文档
> 大家都知道 我们程序员都不擅长写作<br>
> 有时候作者把文档写完了也不知道用户是什么感觉 是否能看懂<br>
> 所以参与社区文档建设绝对是一件意义重大的事情<br>
> 大家可以在Issue提出观后感 觉得哪看不懂 觉得哪应该详细说明<br>
> 当然了 大家也可以对文档进行改进后提交PR修改申请
<font size="6">文档仓库: [plus-doc](https://gitee.com/JavaLionLi/plus-doc) 👈点他点他</font>
![输入图片说明](https://foruda.gitee.com/images/1678935992827063291/d7c4dc5b_1766278.png "屏幕截图")
## 贡献代码
> 想参与贡献代码的小伙伴 重点来了: 作者会经常在Issue里发布需求认领<br>
> 觉得自己能做的可以在Issue里跟作者讨论 如需求还不够清晰 或者做的过程中遇到了什么问题
<img src="https://foruda.gitee.com/images/1678936513184771725/f26349dd_1766278.png" width="550px" height="450px" />
> 需求确定了以后就可以开始专注的写代码了<br>
> 但在开始写代码之前 一定要先看一下如何正确的提交PR
<font size="4">一点要仔细看: [如何提交PR](/common/pr.md) 👈点他点他</font>
## 如何成为项目成员
> 1.对框架有重大贡献者(由作者与团队成员判定)<br>
> 2.完成社区发布的两项复杂任务<br>
> 3.持续完成社区发布的简单任务若干(作者会关注到)<br>
> 4.持续为社区优化文档或处理issue若干(作者会关注到)<br>
## 项目成员待遇
> 1.可免费进入vip收费群<br>
> 2.每年还会发放IDEA正版授权<br>

View File

@@ -0,0 +1,13 @@
# 系统演示(请大家不要乱改数据 影响他人体验 谢谢配合)
- - -
**感谢 `孤舟烟雨` 贡献的演示服务器**
**1核2G 小服务器 经不起压测 请理性操作 违者直接封IP**
> 访问地址: [http://43.138.9.96/](http://43.138.9.96/)
> 登录账户 admin/admin123
> Admin监控中心 ruoyi/123456
> 任务调度中心 admin/123456

View File

@@ -0,0 +1,37 @@
# 如何提交PR贡献代码
- - -
### 步骤一 Fork项目到自己仓库
![输入图片说明](https://foruda.gitee.com/images/1673427084798343408/142a55d0_1766278.png "屏幕截图")
### 步骤二 基于dev分支 新建一个此PR功能点的专属分支
![输入图片说明](https://foruda.gitee.com/images/1673427220695789412/14c4f4ff_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1673427193964585607/16ea99d9_1766278.png "屏幕截图")
### 步骤三 使用Git工具 将自己仓库的项目拉去到本地做代码编写
![输入图片说明](https://foruda.gitee.com/images/1673427313201488937/f2df59bf_1766278.png "屏幕截图")
### 步骤四 使用Idea打开项目 切换到新建的功能分支
![输入图片说明](https://foruda.gitee.com/images/1673427394686229310/c479a5a5_1766278.png "屏幕截图")
### 步骤五 将编写好的代码 提交到自己的远程仓库
![输入图片说明](https://foruda.gitee.com/images/1673427519150795591/d88c2bc9_1766278.png "屏幕截图")
### 步骤六 创建PR申请(此操作在自己仓库或者要PR的仓库都可以)
![输入图片说明](https://foruda.gitee.com/images/1673427616155043776/fe2ce097_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1673427865031025513/0f58a137_1766278.png "屏幕截图")
### 步骤七 等待作者评审 按要求更改 直到没有问题后被作者合并
![输入图片说明](https://foruda.gitee.com/images/1673428029932524584/93234628_1766278.png "屏幕截图")
### 评审期间 如需对PR内容做更改 直接在新功能分支提交代码即可
### 无需重复提交PR申请 这边会自动比对两个分支的差异
![输入图片说明](https://foruda.gitee.com/images/1673428054139366497/4ecb6e98_1766278.png "屏幕截图")

View File

@@ -0,0 +1,80 @@
# 使用者登记
- - -
**使用此开源项目的公司或者组织**
> Vue版本登记地址: https://gitee.com/dromara/RuoYi-Vue-Plus/issues/I4QP39
> Cloud版本登记地址: https://gitee.com/dromara/RuoYi-Cloud-Plus/issues/I4VJ7G
| 公司名 | 官网 | LOGO |
|-------------------|:-------------------------------|----------------------------------------------------------------------------------------------------------------|
| 中国联通(长春分公司) | http://www.10010.com | <img src="https://foruda.gitee.com/images/1679554727740431371/bd179d0f_1766278.png" width="300" height="200"> |
| 中国电信(湖南分公司) | http://www.189.cn/hn/ | <img src="https://foruda.gitee.com/images/1699838764871886313/61b44b7d_1766278.png" width="300" height="200"> |
| 南京感知信息技术有限公司 | https://njgzxx.cn/ | <img src="https://foruda.gitee.com/images/1725589695335847776/10bb2088_1766278.png" width="400" height="200"> |
| 陕西骏景索道运营管理有限公司 | https://www.junjingsuodao.com/ | <img src="https://foruda.gitee.com/images/1724394959451680041/24ac17ff_7408092.png" width="300" height="200"> |
| 悠码科技有限公司 | https://orise.trytowish.cn/ | <img src="https://foruda.gitee.com/images/1722916054523975884/686ee49e_8929785.png" width="200" height="200"> |
| 苏州龙的信息系统股份有限公司 | http://www.longdayinfo.com/ | <img src="https://foruda.gitee.com/images/1721182313605689705/f676882a_2113976.png" width="400" height="200"> |
| 北京数通智达科技有限公司 | http://www.bzdtech.com/ | <img src="https://foruda.gitee.com/images/1717744899576682096/7d6cf41f_1766278.png" width="400" height="200"> |
| 广州六六七七科技有限公司 | https://artiversehub.ai/ | <img src="https://foruda.gitee.com/images/1716976454631958575/44abbb05_1766278.png" width="300" height="200"> |
| 宁波三品软件科技有限公司 | http://nbsanpin.com/ | <img src="https://foruda.gitee.com/images/1715845257022437822/1a096edc_14415359.png" width="300" height="200"> |
| 北京御一科技信息技术有限公司 | https://www.yudoctor.com | <img src="https://foruda.gitee.com/images/1715157943995574211/09aa2229_1766278.png" width="400" height="200"> |
| 成都卡恩特医疗科技有限公司 | http://www.scknot.com | <img src="https://foruda.gitee.com/images/1711091474880818044/96ddef90_1766278.png" width="400" height="200"> |
| 无锡科艾思科技有限公司 | https://www.kyoeis.com | <img src="https://foruda.gitee.com/images/1710929131545545232/a87f838e_1766278.png" width="400" height="200"> |
| 深圳市海联天下科技有限公司 | www.sealinkin.com | <img src="https://foruda.gitee.com/images/1709870697911145583/453db298_1766278.png" width="400" height="200"> |
| 上海非定义旅游服务有限公司 | http://www.anonymity.love/ | <img src="https://foruda.gitee.com/images/1706165274431234456/f4be93d3_1766278.png" width="400" height="200"> |
| 重庆威爱云科技有限公司 | https://www.51vive.com | <img src="https://foruda.gitee.com/images/1700460635019084607/f073724d_1766278.png" width="400" height="200"> |
| 中城智联(成都)创新科技有限公司 | http://www.zc-zl.com/ | <img src="https://foruda.gitee.com/images/1699841115050735040/0d6893d1_1766278.png" width="300" height="200"> |
| 浙江海亮股份有限公司 | https://www.hailiangstock.com | <img src="https://foruda.gitee.com/images/1699841174631804104/fd3466fd_1766278.png" width="300" height="200"> |
| 河北雄安山禾咨询工程有限公司 | https://shanheqei.club/ | <img src="https://foruda.gitee.com/images/1699855302878416881/6bfdb2d5_1766278.png" width="300" height="200"> |
| 数舵(河北雄安)信息科技有限公司 | http://www.shuduokeji.com | <img src="https://foruda.gitee.com/images/1698888517162767014/8a2840ff_1766278.png" width="400" height="200"> |
| 南昌鼎欣科技股份有限公司 | https://www.openzt.com | <img src="https://foruda.gitee.com/images/1697701810520579719/4da9666e_1766278.png" width="400" height="200"> |
| 东莞市码载网络科技有限公司 | https://www.codeload.top | <img src="https://foruda.gitee.com/images/1697618746817506398/57af2eaa_10583761.png" width="400" height="200"> |
| 北京农信通科技有限责任公司 | http://www.nxt.com.cn | <img src="https://foruda.gitee.com/images/1696428611360166577/72e7f7c4_971517.png" width="400" height="200"> |
| 中康腾华网络科技(重庆)有限公司 | https://www.zkthwlkj.com/ | <img src="https://foruda.gitee.com/images/1695112845600729239/a16e34e2_1766278.png" width="200" height="100"> |
| 杭州码恒信息科技有限公司 | http://www.mh-barcode.com/ | <img src="https://foruda.gitee.com/images/1690881482450489558/2d689bc1_1766278.png" width="400" height="200"> |
| 南京晶益科技有限公司 | https://www.nanjingjingyi.com/ | <img src="https://foruda.gitee.com/images/1689576488369281878/bec504ce_1766278.png" width="400" height="200"> |
| 合肥智享亿云科技有限公司 | http://www.izxyy.com | <img src="https://foruda.gitee.com/images/1685096398913604988/e6c16816_1766278.png" width="300" height="200"> |
| 锡简科技 | https://www.xj-fast.com | <img src="https://foruda.gitee.com/images/1683858424104223718/172f2c2e_1766278.png" width="300" height="200"> |
| 福建亘前科技有限公司 | https://genqian.top | <img src="https://foruda.gitee.com/images/1683170298723703161/891feff4_1766278.png" width="400" height="200"> |
| 北京联宇信通科技有限公司 | http://www.lyxtkj.com/ | <img src="https://foruda.gitee.com/images/1680068618387237935/5e195ad8_1766278.png" width="400" height="200"> |
| 厦门市熵时光科技有限公司 | https://www.xetsoft.com | <img src="https://foruda.gitee.com/images/1672299365177532128/f0e78c26_1766278.png" width="400" height="200"> |
| 广州润沁教育科技有限公司 | https://www.ca163.net | <img src="https://foruda.gitee.com/images/1678976000893686992/1acbda54_1766278.png" width="400" height="200"> |
| 广东乐善智能装备股份有限公司 | https://www.china-leshan.com/ | <img src="https://foruda.gitee.com/images/1672299473733272899/2065e28c_1766278.png" width="400" height="200"> |
| 数字江西科技有限公司 | https://www.digitaljx.com/ | <img src="https://foruda.gitee.com/images/1660527156328976445/屏幕截图.png" width="300" height="200"> |
| 上海极锐星瀚传感技术有限公司 | http://www.jrsensing.com/ | <img src="https://foruda.gitee.com/images/1669694597446652604/6997f99a_1766278.png" width="400" height="100"> |
| 北京数影互联科技有限公司 | http://www.dataflying.top/ | <img src="https://foruda.gitee.com/images/1686118090145603656/46dbe579_1766278.png" width="200" height="100"> |
| 广州创服信息科技有限公司 | https://www.cfkjcloud.com | <img src="https://foruda.gitee.com/images/1678975960889135530/85fa904f_1766278.png" width="400" height="200"> |
| 茂名云智科技有限公司 | http://www.winzkj.com | <img src="https://foruda.gitee.com/images/1678975967691323451/6343e6b7_1766278.png" width="400" height="200"> |
| 成都时光旅迹科技有限公司 | https://www.ttmup.com/ | <img src="https://foruda.gitee.com/images/1678975973935607983/a0f8dce2_1766278.png" width="400" height="200"> |
| 成都炫影全息科技有限公司 | http://xyqxgs.com | <img src="https://foruda.gitee.com/images/1678975979873588062/e34db081_1766278.png" width="400" height="200"> |
| 中山厚德快速模具有限公司 | http://hordrt.com | <img src="https://foruda.gitee.com/images/1678975986213675141/7436dcb9_1766278.png" width="400" height="200"> |
| 深圳市深南夙星科技有限公司 | http://www.szsnsx.com/ | <img src="https://foruda.gitee.com/images/1678975994674685698/a2c05a6e_1766278.png" width="400" height="200"> |
| 陕西华恒军创信息科技有限公司 | http://hhjc.cc | <img src="https://foruda.gitee.com/images/1678976006389002991/3786a1bc_1766278.png" width="400" height="200"> |
| 河南小牛信息科技有限公司 | http://www.hnxn888.com/ | <img src="https://foruda.gitee.com/images/1681106560964010687/d8969ed2_1766278.png" width="200" height="100"> |
| 武汉华智讯网络信息技术有限公司 | http://www.xun188.com | <img src="https://foruda.gitee.com/images/1678975944577016382/93c4541d_1766278.png" width="200" height="100"> |
| 易税信息技术有限公司 | https://www.etax.top | <img src="https://foruda.gitee.com/images/1678975950137235651/211a63c4_1766278.png" width="200" height="100"> |
| 广西华景城建筑设计有限公司 | http://www.hjcadc.com | <img src="https://foruda.gitee.com/images/1678975955216975234/e83c8c6e_1766278.png" width="200" height="100"> |
| 铭创科技有限公司 | https://www.mcck.cn/ | <img src="https://foruda.gitee.com/images/1693967206668467582/8c234a6d_1766278.png" width="200" height="100"> |
| 西安鼎慧网络科技有限公司 | | <img src="https://foruda.gitee.com/images/1721271356660437424/b85c5754_8776295.jpeg" width="400" height="200"> |
| 营口鼎瑞网络科技有限公司 | | <img src="https://foruda.gitee.com/images/1715836865319520119/5dc34a5f_8693506.png" width="400" height="200"> |
| 南昌漫库书店有限公司 | | <img src="https://foruda.gitee.com/images/1687656369793887183/ce1a33f6_1766278.png" width="200" height="100"> |
| 广西文韬智能科技有限公司 | | <img src="https://foruda.gitee.com/images/1678976034543683491/8d8a1ebe_1766278.png" width="200" height="100"> |
| 贵州亿瑞祺科技有限公司 | |
| 贵州新绿视界环保科技有限公司 | |
| 湖南智才伯乐数据科技有限公司 | |
| 德州商储超市有限公司 | |
| 曲沃亿分科技中心 | |
| 南京杰度信息技术有限公司 | |
| 武汉忆秋科技有限公司 | |
| 济南千惠网络科技有限公司 | |
| 江苏泛联科技有限公司 | |
| 沈阳市果冻网络信息科技有限责任公司 | |
| 灵劲科技有限公司 | |
| 亿世达餐饮管理(北京)有限公司 | |
| 深圳市凯帝电子商务有限公司 | |
| 成都数智源蓉卡科技有限公司 | |
| 上海振福信息科技有限公司 | |
| 重庆六客会科技有限公司 | |
| 无限创优(西安)科技有限公司 | |
| 惠族网络科技发展有限公司 | |
| 纳森科技有限公司 | |

View File

@@ -0,0 +1,85 @@
# 视频教程(联合出品)
### 主讲与后期剪辑: `抓蛙师`
抓蛙师简介: B站知名UP主 B站首页: https://space.bilibili.com/520725002
### 知识点统筹与内容审核: `疯狂的狮子Li`
疯狂的狮子Li简介: RuoYi-Vue-Plus 与 RuoYi-Cloud-Plus 作者
## 已完结🎉🎉🎉 优惠价: 598(仅限前500名) ~~原价: 698~~
**注意: 视频采用 RuoYi-Vue-Plus 版本 4.X 分支讲解!!! (内容为通用技术与版本关联性不大)**<br>
**内容为框架内所用到的技术与设计原理(打破不知道、不会用、不知应用场景等问题)**
课程简介: https://www.bilibili.com/video/BV16j411D7BX/
<br>
试看课程: https://www.bilibili.com/video/BV1uS411P7JD/
<br>
试看课程: https://www.bilibili.com/video/BV1vLbNeuESn/
<br>
试看课程: https://www.bilibili.com/video/BV1xV4y127KM/
<br>
试看课程: https://www.bilibili.com/video/BV1W5v8eBEgs/
<br>
课程总结: https://www.bilibili.com/video/BV1734y1g7fk/
<br>
## 购买方式
**小本生意 用心录制 拒绝砍价 已更新到 236 集 课程完结**<br>
> 课程咨询或购买请联系 价格598<br>
> QQ: 906670865 (疯狂的狮子Li)<br>
> QQ: 770492966 (抓蛙师)
## 购买前常见问题答疑
> 问题1: 购买后是否有群可以解答问题<br>
> 答: 购买后有专属课程付费群(千人大群)讲师在线答疑
>
> 问题2: 是否持续更新 如新版本功能<br>
> 答: 课程目录即为全部课程内容 以课程目录为准 明年大概会出二期来讲新版本内容<br>
> 因为持续更新会导致前面的技术老旧 新购买的人无法及时学习新技术<br>
> 故而采用分期出课程制度 已经购买过的老客户 再次购买下一次会给力度非常大的折扣
>
> 问题3: 目前视频未全部录制完成 后续更新是否二次收费<br>
> 答: 视频目录即为全部视频内容 一次收费后续更新仍然可看直到视频全部更新完成(明年出二期课程不算在内)
>
> 问题4: 视频如何下载如何观看<br>
> 答: 视频文件已加密 采用专门的播放器(播放器只限制截图录屏等不限制其他软件使用) 由管理员发放授权码观看<br>
> 支持通过 百度云 或者 阿里云 网盘下载视频资源
>
> 问题5: 视频平均时长和总时长大概多久<br>
> 答: 视频每集短的大概10分钟以上 长的大概40个分钟左右 平均时长20多分钟每集<br>
> 目前已经录制了236集总时长为80多个小时
>
> 问题6: 是否有讲解 Cloud 版本相关内容<br>
> 答: 视频主要讲解内容为框架内所用到的技术与设计原理 无论什么版本 功能和设计都是一样的<br>
> Cloud 版本只是多了 alibaba 的几个组件完全可以B站自学
## 课程目录
![输入图片说明](https://foruda.gitee.com/images/1695105467795304336/58fcd6db_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105494170842444/10f98fed_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105523526589287/f131c614_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105547992880680/9f4137f3_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105560849590514/d19fad6a_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105586641712428/349a971b_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105595501187093/fb819d35_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105609163585390/833dd89c_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105630469565265/8dbba1d2_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695105659037093525/09a4f6e1_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1695714493079698007/311980ee_1766278.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1697446957351573520/cab3617d_1766278.png "屏幕截图")
## 学员观后感
| | |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| ![输入图片说明](https://foruda.gitee.com/images/1691386100129796781/44b69dae_1766278.jpeg "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1691386076834242484/a6073f7d_1766278.png "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1691386089186649583/98ac8b7c_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1691386108722171132/b937b23a_1766278.jpeg "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1695714607596127461/513b6893_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1692804549604261480/09ef12f6_1766278.png "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1692804541482477905/578e5448_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1695714614517941469/cac681fb_1766278.png "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1698225407961714462/4d271901_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1698225416488201339/30572e7f_1766278.png "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1698807198508085566/16c37a1b_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1698807208125772586/ceed632e_1766278.png "屏幕截图") |
| ![输入图片说明](https://foruda.gitee.com/images/1698807214013013096/ad3bc016_1766278.png "屏幕截图") | ![输入图片说明](https://foruda.gitee.com/images/1698807221010472627/72b10901_1766278.png "屏幕截图") |

View File

@@ -0,0 +1,74 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>plus-doc</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
<meta name="description" content="Description">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<!-- 设置浏览器图标 -->
<link rel="icon" href="./static/image/favicon.ico" type="image/x-icon"/>
<link rel="shortcut icon" href="./static/image/favicon.ico" type="image/x-icon"/>
<meta charset="UTF-8">
<!-- 默认主题 -->
<link rel="stylesheet" href="./static/css/vue.css">
</head>
<body>
<div id="app"></div>
<script>
window.$docsify = {
// 项目名称
name: 'ruoyi-ai',
// 仓库地址点击右上角的Github章鱼猫头像会跳转到此地址
repo: 'https://gitee.com/ruoyi-ai',
// 侧边栏支持默认加载的是项目根目录下的_sidebar.md文件
loadSidebar: true,
// 导航栏支持默认加载的是项目根目录下的_navbar.md文件
loadNavbar: true,
// 封面支持默认加载的是项目根目录下的_coverpage.md文件
coverpage: true,
// 最大支持渲染的标题层级
maxLevel: 5,
// 自定义侧边栏后默认不会再生成目录设置生成目录的最大层级建议配置为2-4
subMaxLevel: 4,
// 小屏设备下合并导航栏到侧边栏
mergeNavbar: true,
// 页脚支持,默认加载的是 _footer.md
loadFooter: true,
// 首页只展示封面默认为false与README.md进行拼接
onlyCover: true,
search: {
maxAge: 86400000,// 过期时间,单位毫秒,默认一天
paths: 'auto',// 注意:仅适用于 paths: 'auto' 模式
placeholder: '👉👉👉在这里搜索关键字👈👈👈',
noData: '找不到结果',
depth: 4,
hideOtherSidebarContent: false,
namespace: 'Docsify-Guide',
}
}
</script>
<!-- docsify的js依赖 -->
<script src="./static/js/docsify.min.js"></script>
<!-- emoji表情支持 -->
<script src="./static/js/emoji.min.js"></script>
<!-- 图片放大缩小支持 -->
<script src="./static/js/zoom-image.min.js"></script>
<!-- 搜索功能支持 -->
<script src="./static/js/search.min.js"></script>
<!--在所有的代码块上添加一个简单的Click to copy按钮来允许用户从你的文档中轻易地复制代码-->
<script src="./static/js/docsify-copy-code.min.js"></script>
<!-- 回到顶部 -->
<script src="./static/js/docsify-scroll-to-top.min.js"></script>
<!-- 分页导航 -->
<script src="./static/js/docsify-pagination.min.js"></script>
<!-- 页脚-->
<script src="./static/js/docsify-footer.min.js"></script>
<!-- 代码高亮 -->
<script src="./static/js/prism-typescript.min.js"></script>
<script src="./static/js/prism-bash.min.js"></script>
</body>
</html>

View File

@@ -0,0 +1,22 @@
<!-- _sidebar.md -->
- **特别赞助**
- [![输入图片说明](https://foruda.gitee.com/images/1704162419429172656/d0521e59_1766278.png "2024-01-02=>2028-01-02")](http://ccflow.org/?frm=ryPlus)
- [![输入图片说明](https://foruda.gitee.com/images/1705569347386939952/3f187980_1766278.jpeg "2024-01-18=>2025-01-18")](http://www.shuduokeji.com)
- [![输入图片说明](https://foruda.gitee.com/images/1711681233267310022/2ffbcff2_1766278.png "2024-03-29=>2025-03-29")](https://www.jnpfsoft.com/index.html?from=plus-doc)
* **简介**
* [项目简介](/plus-ui/home.md)
* **开发文档**
* [通用方法](/plus-ui/devdoc/common_func.md)
* [开发规范](/plus-ui/devdoc/dev_norm.md)
* [请求流程](/plus-ui/devdoc/request_process.md)
* [路由使用](/plus-ui/devdoc/router_use.md)
* [组件使用](/plus-ui/devdoc/component_use.md)
* [权限使用](/plus-ui/devdoc/permissions_use.md)
* [页签缓存](/plus-ui/devdoc/page_cache.md)
* [使用图标](/plus-ui/devdoc/icon_use.md)
* [使用字典](/plus-ui/devdoc/dict_use.md)
* [使用参数](/plus-ui/devdoc/param_use.md)
* [异常处理](/plus-ui/devdoc/exception_handling.md)
* [内容复制](/plus-ui/devdoc/content_copy.md)

View File

@@ -0,0 +1,234 @@
# 通用方法
- - -
### $tab对象
> `$tab`对象用于做页签操作、刷新页签、关闭页签、打开页签、修改页签等,它定义在`plugins/tab.ts`文件中,它有如下方法
* 打开页签
```typescript
// 打开页签
proxy?.$tab.openPage('/system/user');
// 打开页签并指定页签标题
proxy?.$tab.openPage('/system/user', '用户管理');
proxy?.$tab.openPage('/system/user', '用户管理').then(() => {
// 执行结束的逻辑
})
```
* 修改页签
```typescript
// 修改当前页签
const obj = Object.assign({}, route, { title: '自定义标题' });
proxy?.$tab.updatePage(obj);
```
* 关闭页签
```typescript
// 关闭当前
proxy?.$tab.closePage();
// 关闭指定页签
const obj = { path: "/system/user", name: "User" };
proxy?.$tab.closePage(obj);
proxy?.$tab.closePage(obj).then(() => {
// 执行结束的逻辑
})
```
* 刷新页签
```typescript
// 刷新当前页签
proxy?.$tab.refreshPage();
// 刷新指定页签
const obj = { path: "/system/user", name: "User" };
proxy?.$tab.refreshPage(obj);
proxy?.$tab.refreshPage(obj).then(() => {
// 执行结束的逻辑
})
```
* 关闭所有页签
```typescript
proxy?.$tab.closeAllPage();
proxy?.$tab.closeAllPage().then(() => {
// 执行结束的逻辑
})
```
* 关闭左侧页签
```typescript
// 关闭当前页签的左侧页签
proxy?.$tab.closeLeftPage();
// 关闭指定页签的左侧页签
const obj = { path: "/system/user", name: "User" };
proxy?.$tab.closeLeftPage(obj);
proxy?.$tab.closeLeftPage(obj).then(() => {
// 执行结束的逻辑
})
```
* 关闭右侧页签
```typescript
// 关闭当前页签的右侧页签
proxy?.$tab.closeRightPage();
// 关闭指定页签的右侧页签
const obj = { path: "/system/user", name: "User" };
proxy?.$tab.closeRightPage(obj);
proxy?.$tab.closeRightPage(obj).then(() => {
// 执行结束的逻辑
})
```
* 关闭其他页签
```typescript
proxy?.$tab.closeOtherPage();
const obj = { path: "/system/user", name: "User" };
proxy?.$tab.closeOtherPage(obj);
proxy?.$tab.closeOtherPage(obj).then(() => {
// 执行结束的逻辑
})
```
### $modal对象
> `$modal`对象用于做消息提示、通知提示、对话框提醒、二次确认、遮罩等,它定义在`plugins/modal.ts`文件中,它有如下方法
* 提供成功、警告和错误等反馈信息
```typescript
proxy?.$modal.msg("默认反馈");
proxy?.$modal.msgError("错误反馈");
proxy?.$modal.msgSuccess("成功反馈");
proxy?.$modal.msgWarning("警告反馈");
```
* 提供成功、警告和错误等提示信息
```typescript
proxy?.$modal.alert("默认提示");
proxy?.$modal.alertError("错误提示");
proxy?.$modal.alertSuccess("成功提示");
proxy?.$modal.alertWarning("警告提示");
```
* 提供成功、警告和错误等通知信息
```typescript
proxy?.$modal.notify("默认通知");
proxy?.$modal.notifyError("错误通知");
proxy?.$modal.notifySuccess("成功通知");
proxy?.$modal.notifyWarning("警告通知");
```
* 提供确认窗体信息
```typescript
proxy?.$modal.confirm('确认信息').then(function() {
...
}).then(() => {
...
}).catch(() => {});
```
* 提供遮罩层信息
```typescript
// 打开遮罩层
proxy?.$modal.loading("正在导出数据,请稍后...");
// 关闭遮罩层
proxy?.$modal.closeLoading();
```
### $auth对象
> `$auth`对象用于验证用户是否拥有某(些)权限或角色,它定义在`plugins/auth.ts`文件中,它有如下方法
* 验证用户权限
```typescript
// 验证用户是否具备某权限
proxy?.$auth.hasPermi("system:user:add");
// 验证用户是否含有指定权限,只需包含其中一个
proxy?.$auth.hasPermiOr(["system:user:add", "system:user:update"]);
// 验证用户是否含有指定权限,必须全部拥有
proxy?.$auth.hasPermiAnd(["system:user:add", "system:user:update"]);
```
* 验证用户角色
```typescript
// 验证用户是否具备某角色
proxy?.$auth.hasRole("admin");
// 验证用户是否含有指定角色,只需包含其中一个
proxy?.$auth.hasRoleOr(["admin", "common"]);
// 验证用户是否含有指定角色,必须全部拥有
proxy?.$auth.hasRoleAnd(["admin", "common"]);
```
### $cache对象
> `$cache`对象用于处理缓存。我们并不建议您直接使用`sessionStorage`或`localStorage`(vue3版本推荐使用useStorage),因为项目的缓存策略可能发生变化,通过`$cache`对象做一层调用代理则是一个不错的选择。`$cache`提供`session`和`local`两种级别的缓存,如下:
| 对象名称 | 缓存类型 |
| -------- | ---------------------------------- |
| session | 会话级缓存通过sessionStorage实现 |
| local | 本地级缓存通过localStorage实现 |
**示例**
```typescript
// local 普通值
proxy?.$cache.local.set('key', 'local value')
console.log(proxy?.$cache.local.get('key')) // 输出'local value'
// session 普通值
proxy?.$cache.session.set('key', 'session value')
console.log(proxy?.$cache.session.get('key')) // 输出'session value'
// local JSON值
proxy?.$cache.local.setJSON('jsonKey', { localProp: 1 })
console.log(proxy?.$cache.local.getJSON('jsonKey')) // 输出'{localProp: 1}'
// session JSON值
proxy?.$cache.session.setJSON('jsonKey', { sessionProp: 1 })
console.log(proxy?.$cache.session.getJSON('jsonKey')) // 输出'{sessionProp: 1}'
// 删除值
proxy?.$cache.local.remove('key')
proxy?.$cache.session.remove('key')
```
### $download对象
> `$download`对象用于文件下载,它定义在`plugins/download.ts`文件中,它有如下方法
* 通过ossId从存储中下载文件
``` typescript
// 默认下载方法
proxy?.$download.oss(ossId);
```
* 根据请求地址下载zip包
```typescript
const url = '/tool/gen/batchGenCode?tables=' + tableNames;
const name = 'ruoyi';
// 默认方法
proxy?.$download.zip(url, name);
```

View File

@@ -0,0 +1,55 @@
# 组件使用
- - -
vue 注册组件的两种方式
`@/components` 下创建的.vue文件自动为全局组件可直接在任意位置使用。
### 局部注册
在对应页使用`components`注册组件。
```typescript
<script setup lang=ts>
import ComponentA from './ComponentA.vue'
</script>
<template>
<ComponentA />
</template>
```
### 全局注册
我们可以使用[ Vue 应用实例](https://cn.vuejs.org/guide/essentials/application.html)的 `.component()` 方法,让组件在当前 Vue 应用中全局可用。
```typescript
import { createApp } from 'vue'
const app = createApp({})
app.component(
// 注册的名字
'MyComponent',
// 组件的实现
{
/* ... */
}
)
```
如果使用单文件组件,你可以注册被导入的 `.vue` 文件:
```typescript
import MyComponent from './App.vue'
app.component('MyComponent', MyComponent)
```
`.component()` 方法可以被链式调用:
```typescript
app
.component('ComponentA', ComponentA)
.component('ComponentB', ComponentB)
.component('ComponentC', ComponentC)
```
全局注册的组件可以在此应用的任意组件的模板中使用:
```Typescript
// 这在当前应用的任意组件中都可用
<ComponentA/>
<ComponentB/>
<ComponentC/>
```
所有的子组件也可以使用全局注册的组件,这意味着这三个组件也都可以在彼此内部使用。

View File

@@ -0,0 +1,4 @@
# 内容复制
- - -
文档建设中

View File

@@ -0,0 +1,16 @@
# 开发规范
- - -
### 新增view
> 在`@/views`文件下创建对应的文件夹,一般性一个路由对应一个文件, 该模块下的功能就建议在本文件夹下创建一个新文件夹,各个功能模块维护自己的`utils`或`components`组件。
### 新增api
> 在`@/api`文件夹下创建本模块对应的api服务。
> 在api服务同级创建`types.ts`类型声明文件。
### 新增组件
> 在全局的`@/components`写一些全局的组件,如富文本,各种搜索组件,封装的分页组件等等能被公用的组件。 每个页面或者模块特定的业务组件则会写在当前`@/views`下面。
如:`@/views/system/user/components/xxx.vue`。这样拆分大大减轻了维护成本。
### 新增样式
> 页面的样式和组件是一个道理,全局的`@/style`放置一下全局公用的样式,每一个页面的样式就写在当前 views下面请记住加上scoped 就只会作用在当前组件内了,避免造成全局的样式污染。

View File

@@ -0,0 +1,4 @@
# 使用字典
- - -
文档建设中

View File

@@ -0,0 +1,4 @@
# 异常处理
- - -
文档建设中

View File

@@ -0,0 +1,4 @@
# 使用图标
- - -
文档建设中

View File

@@ -0,0 +1,4 @@
# 页签缓存
- - -
文档建设中

View File

@@ -0,0 +1,4 @@
# 使用参数
- - -
文档建设中

View File

@@ -0,0 +1,4 @@
# 权限使用
- - -
文档建设中

View File

@@ -0,0 +1,65 @@
# 请求流程
- - -
### 交互流程
一个完整的前端UI交互到服务器端处理流程是这样的
1. UI 组件交互操作;
2. 调用统一管理的 api service 请求函数;
3. 使用封装的 request.js 发送请求;
4. 获取服务端返回;
5. 更新 data
为了方便管理维护,统一的请求处理都放在`@/src/api`文件夹中,并且一般按照`model`维度进行拆分文件,如:
```
api/
system/
user/
index.ts
types.ts
role/
index.ts
types.ts
monitor/
operlog/
index.ts
types.ts
logininfor/
index.ts
types.ts
...
```
> **提示**
> 其中`@/src/utils/request.ts`是基于 axios 的封装,便于统一处理 POSTGET 等请求参数,请求头,以及错误提示信息等。 它封装了全局request拦截器、response拦截器、统一的错误处理、统一做了超时处理、baseURL设置等。
### 请求示例
```typescript
// @/api/system/user/index.ts
import request from '@/utils/request';
import { AxiosPromise } from 'axios';
import { UserQuery, UserVO } from './types';
export const listUser = (query: UserQuery): AxiosPromise<UserVO[]> => {
return request({
url: '/system/user/list',
method: 'get',
params: query
});
};
// @/views/system/user/index.vue
import api from '@/api/system/user';
const res = await api.listUser(proxy?.addDateRange(queryParams.value, dateRange.value));
```
> **提示**
> 如果有不同的`baseURL`,直接通过覆盖的方式,让它具有不同的`baseURL`。
> ```typescript
> export const listUser = (query: UserQuery): AxiosPromise<UserVO[]> => {
> return request({
> url: '/system/user/list',
> method: 'get',
> params: query,
> baseURL: process.env.BASE_API
> });
> };
> ```

View File

@@ -0,0 +1,82 @@
# 路由使用
- - -
框架的核心是通过路由自动生成对应导航,所以除了路由的基本配置,还需要了解框架提供了哪些配置项。
### 路由配置
```typescript
// 当设置 true 的时候该路由不会在侧边栏出现 如401login等页面或者如一些编辑页面/edit/1
hidden: true // (默认 false)
//当设置 noRedirect 的时候该路由在面包屑导航中不可被点击
redirect: 'noRedirect'
// 当你一个路由下面的 children 声明的路由大于1个时自动会变成嵌套的模式--如组件页面
// 只有一个时,会将那个子路由当做根路由显示在侧边栏--如引导页面
// 若你想不管路由下面的 children 声明的个数都显示你的根路由
// 你可以设置 alwaysShow: true这样它就会忽略之前定义的规则一直显示根路由
alwaysShow: true
name: 'router-name' // 设定路由的名字,一定要填写不然使用<keep-alive>时会出现各种问题
query: '{"id": 1, "name": "ry"}' // 访问路由的默认传递参数
roles: ['admin', 'common'] // 访问路由的角色权限
permissions: ['a:a:a', 'b:b:b'] // 访问路由的菜单权限
meta: {
title: 'title' // 设置该路由在侧边栏和面包屑中展示的名字
icon: 'svg-name' // 设置该路由的图标,支持 svg-class也支持 el-icon-x element-ui 的 icon
noCache: true // 如果设置为true则不会被 <keep-alive> 缓存(默认 false)
breadcrumb: false // 如果设置为false则不会在breadcrumb面包屑中显示(默认 true)
affix: true // 如果设置为true它则会固定在tags-view中(默认 false)
// 当路由设置了该属性,则会高亮相对应的侧边栏。
// 这在某些场景非常有用,比如:一个文章的列表页路由为:/article/list
// 点击文章进入文章详情页,这时候路由为/article/1但你想在侧边栏高亮文章列表的路由就可以进行如下设置
activeMenu: '/article/list'
}
```
**普通示例**
```json
{
path: '/system/test',
component: Layout,
redirect: 'noRedirect',
hidden: false,
alwaysShow: true,
meta: { title: '', icon : "system" },
children: [{
path: 'index',
component: (resolve) => require(['@/views/index'], resolve),
name: 'Test',
meta: {
title: '',
icon: 'user'
}
}]
}
```
**外链示例**
```json
{
path: 'http://ruoyi.vip',
meta: { title: '', icon : "guide" }
}
```
### 静态路由
代表那些不需要动态判断权限的路由如登录页、404、等通用页面`@/router/index.ts`配置对应的公共路由。
### 动态路由
代表那些需要根据用户动态判断权限并通过addRoutes动态添加的页面`@/store/modules/permission.ts`加载后端接口路由配置。
> **提示**
> * 动态路由可以在系统管理-菜单管理进行新增和修改操作,前端加载会自动请求接口获取菜单信息并转换成前端对应的路由。
> * 动态路由在生产环境下会默认使用路由懒加载实现方式参考loadView方法的判断。
### 常用方法
想要跳转到不同的页面,使用`router.push`方法
```Typescript
const router = useRouter();
router.push({ path: "/system/user" });
```
跳转页面并设置请求参数,使用`query`属性
```Typescript
const router = useRouter();
router.push({ path: "/system/user", query: {id: "1", name: "若依"} });
```
更多使用可以参考[vue-router](https://router.vuejs.org/zh/)官方文档。

View File

@@ -0,0 +1,53 @@
# 项目简介
---
## 平台简介
- 本仓库为前端技术栈 [Vue3](https://v3.cn.vuejs.org) + [Element Plus](https://element-plus.org/zh-CN) + [Vite](https://cn.vitejs.dev) 版本。
- 配套后端代码仓库地址
- [RuoYi-Vue-Plus 5.X(注意版本号)](https://gitee.com/dromara/RuoYi-Vue-Plus)
- [RuoYi-Cloud-Plus 2.X(注意版本号)](https://gitee.com/dromara/RuoYi-Cloud-Plus)
## 前端运行
```bash
# 克隆项目
git clone https://gitee.com/JavaLionLi/plus-ui.git
# 安装依赖
npm install --registry=https://registry.npmmirror.com
# 启动服务
npm run dev
# 推荐使用yarn或pnpm包管理工具
# 构建测试环境 yarn build:stage
# 构建生产环境 yarn build:prod
# 前端访问地址 http://localhost:80
```
## 后端改造
参考后端代码内 `ruoyi-gen/resources/vm/vue/v3/readme.txt` 说明
## 内置功能
1. 租户管理:配置系统租户,支持 SaaS 场景下的多租户功能。
2. 用户管理:用户是系统操作者,该功能主要完成系统用户配置。
3. 部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。
4. 岗位管理:配置系统用户所属担任职务。
5. 菜单管理:配置系统菜单,操作权限,按钮权限标识等。
6. 角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。
7. 字典管理:对系统中经常使用的一些较为固定的数据进行维护。
8. 参数管理:对系统动态配置常用参数。
9. 通知公告:系统通知公告信息发布维护。
10. 操作日志:系统正常操作日志记录和查询;系统异常信息日志记录和查询。
11. 登录日志:系统登录日志记录查询包含登录异常。
12. 在线用户:当前系统中活跃用户状态监控。
13. 定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。
14. 代码生成前后端代码的生成java、html、xml、sql支持 CRUD 下载 。
15. 系统接口:根据业务代码自动生成相关的 api 接口文档。
16. 服务监控:监视当前系统 CPU、内存、磁盘、堆栈等相关信息。
17. 缓存监控:对系统的缓存信息查询,命令统计等。
18. 在线构建器:拖动表单元素生成相应的 HTML 代码。(TS 版本正在开发中。)

View File

@@ -0,0 +1,34 @@
<!-- _sidebar.md -->
- **特别赞助**
- [![输入图片说明](https://foruda.gitee.com/images/1704162419429172656/d0521e59_1766278.png "2024-01-02=>2028-01-02")](http://ccflow.org/?frm=ryPlus)
- [![输入图片说明](https://foruda.gitee.com/images/1705569347386939952/3f187980_1766278.jpeg "2024-01-18=>2025-01-18")](http://www.shuduokeji.com)
- [![输入图片说明](https://foruda.gitee.com/images/1711681233267310022/2ffbcff2_1766278.png "2024-03-29=>2025-03-29")](https://www.jnpfsoft.com/index.html?from=plus-doc)
* **常见问题**
* [Lombok注解爆红](/questions/lombok.md)
* [如何使用Tomcat](/questions/use_tomcat.md)
* [如何使用druid连接池](/questions/use_druid.md)
* [vue与boot整合部署](/questions/deploy_vue.md)
* [导入excel实体类为空](/questions/import_excel.md)
* [如何同步项目更新](/questions/synchronous_update.md)
* [ParseException SQL解析异常](/questions/parse_exception.md)
* [swagger相关问题](/questions/swagger.md)
* [实体bean为空问题](/questions/bean_null.md)
* [Redis 报错 Permission denied](/questions/permission_denied.md)
* [关于HTTPS配置](/questions/https_config.md)
* [放行接口提示认证失败](/questions/identify_fail.md)
* [打包jar运行报错](/questions/jar_run_fail.md)
* [如何指定dubbo注册ip](/questions/dubbo_ip.md)
* [Sentinel页面404问题](/questions/sentinel_404.md)
* [无法读取nacos配置](/questions/nacos_read_fail.md)
* [接口文档对接knife4j](/questions/kinfe4j.md)
* [不支持ST请求](/questions/st_not_support.md)
* [Only one connection receive subscriber allowed](/questions/only_one_subscriber.md)
* [nacos 报错 The Raft Group [naming_instance_metadata]](/questions/nacos_naming_instance_metadata.md)
* [unable to read meta-data for class xxx](/questions/read_metadata.md)
* [JCE cannot authenticate the provider BC](/questions/jce_cannot.md)
* [关于请求响应参数解密](/questions/api_encrypt.md)
* [关于登录调试步骤](/questions/login_step.md)
* [如何对接国产数据库](/questions/domestic_databases.md)

View File

@@ -0,0 +1,148 @@
# 关于请求响应参数解密
---
## 1前端加密请求
![输入图片说明](https://foruda.gitee.com/images/1717033672316716771/8e30a2f1_4959041.png "屏幕截图")
通过控制台获取加密结果:
![输入图片说明](https://foruda.gitee.com/images/1717033792384655437/900a0e0d_4959041.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1717033896868612970/55581f0a_4959041.png "屏幕截图")
加密密钥:
```
PAg/fZzpV/cz0T1fMUJMJo/LEZvwVLb4bZgtCHkbB6FQAJWlLm/RLKtQ5fOo1blMjAkY+9ryWhsAfCqoMPTU4w==
```
请求参数加密结果:
```
F+Qxq6PzShcudDsUZHhp50lA67eBeTe63x5uGbdm/HJGgcDmjKncUk5VQm0evD8pz1sbmCbmmSl3X1D07K/qgHvP1YhjYSRBJf/M0GTfMkfOZqIkOtvfE5Z6fSFd8RYf6ji/qYxAmCiRmP/uADyJUAoBY1gMi5+zuvyHH3In/FyoFeD0rmJWvO4o4fn3n5GElHMWbP0O/HWPfgHFfg1F7bZQPuf4zAuDKQIqUG3jJTem3O97kAbTWw6lSSuYi1/8tV4cE9rq8SMSjx36/ZLSog==
```
### 解密步骤
1. 使用配置文件私钥对加密密钥解密
```java
// 参数说明:
// requestKey即请求标头加密密钥
// privateKeyapplication.yml 配置文件私钥
String decryptByRsa = EncryptUtils.decryptByRsa(requestKey, privateKey);
```
2. 对步骤一结果进行 Base64 解密,得到 AES 加密密钥
```java
String aesPassword = EncryptUtils.decryptByBase64(decryptByRsa);
```
3. 使用步骤二得到的密钥,对请求参数进行解密
```java
String decryptBody = EncryptUtils.decryptByAes(requestBody, aesPassword);
```
得到解密请求参数(已格式化):
```json
{
"tenantId": "000000",
"username": "admin",
"password": "admin123",
"rememberMe": false,
"uuid": "a39962b22c874f60872ef5db1cd811f5",
"code": "5",
"clientId": "e5cd7e4891bf95d1d19206ce24a7b32e",
"grantType": "password"
}
```
|参数名|说明|
|---|---|
|tenantId| 租户id |
|username| 用户名 |
|password| 密码 |
|rememberMe| 记住密码 |
|uuid| - |
|code| 验证码结果 |
|clientId| 客户端id表 sys_client |
|grantType| 授权类型(表 sys_client |
## 2后端加密响应
对请求使用了注解 `@ApiEncrypt(response = true)`
![输入图片说明](https://foruda.gitee.com/images/1717035066844744866/2286b394_4959041.png "屏幕截图")
通过控制台获取加密结果:
![输入图片说明](https://foruda.gitee.com/images/1717035156784270596/156f2aa7_4959041.png "屏幕截图")
![输入图片说明](https://foruda.gitee.com/images/1717035193189175688/214631e5_4959041.png "屏幕截图")
加密密钥:
```
MXnKYnXcXeFYWKZg8utuhDtbz54cPDcov11E1KT5l19/vMt37d4NhzzwBWnqug72SOgOK5URGaWPJSs9VdaP0Q==
```
响应参数加密结果:
```
70 O63EMmwvbAyWPqDDmVOGTy+BOQnIVgKInMFNRtp8Zwzs8DEL20VgL2IslYrL8bc1u7lPhYNU/6 Q3iTYebm4EokwiG+styaT+LO3M9bUimggoAGpBTW8gCRF/34 kJaOITSRqYqYcXIJKn73+Gqn7jevyKUHyRXog/3 q/PlBdmUjNiB4gtxlOO/Vm+4 o+0 W4jcEe0xwwzV91+Ze3S6Eu/1 XN21g0iOsYT34emv/vhd9Hy3p5LfJlAHvn96x/c3MQBQUU32uM3Vkk3o6IpVHjJljE64gnGximSwB9vrmMA21xX+fq9HYioumknmDDbaY/JAKh32CDgn5M5hdaIklf08sU38r1IyvipySzrHX+ci9GmOZhP2ttCtoZ7SGvFFbNEuyojssxwxXEmJHAsG/OhIAeRXMUr3+dzDJ++XvvMuMgNJR0BMldNydFAjNOQEszgcVM1QEGwxfW5rElW8VxQaaqPyDATX+y2JrK1vdKxxdI/hF5dGpQMdU4FAEhHIftoIbD/FH4XcWJamZjJpbVtZvTkFYpbhiU7sz9MICSuKwaoSFJ8JGANc0bDdVoWpA8sXi7a27IM0pDzk9gD/FADcFGHXxPYUhENkXiUcnmg5LSdigiY4J6HrqEJdH6zNSwoGubcsXhiPdlB3V0DqcLAHFt+GYj5lcxZeqUAmixGVGCV7gSBWNiyo9/NnXcynA/EIlV3OZIvgzjWxiKzcVJ1HOKoXGEcg3Q54QNh5pCqEa7AtqVkKO7/Ffgg8nSEeCdJPzTV7zmr3n94Hn671OL8A==
```
### 解密步骤
1. 使用前端配置文件私钥对加密密钥解密
```java
// 参数说明:
// responseKey即响应标头加密密钥
// privateKey前端 .env.development | .env.production 配置文件私钥,注意和后端私钥区分
String decryptByRsa = EncryptUtils.decryptByRsa(responseKey, privateKey);
```
2. 对步骤一结果进行 Base64 解密,得到 AES 加密密钥
```java
String aesPassword = EncryptUtils.decryptByBase64(decryptByRsa);
```
3. 使用步骤二得到的密钥,对响应参数进行解密
```java
String decryptBody = EncryptUtils.decryptByAes(responseBody, aesPassword);
```
得到解密请求参数(已格式化):
```json
{
"code": 200,
"msg": "操作成功",
"data": {
"scope": null,
"openid": null,
"access_token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJsb2dpblR5cGUiOiJsb2dpbiIsImxvZ2luSWQiOiJzeXNfdXNlcjoxIiwicm5TdHIiOiJjOVNWU1hRRVY4QVhFRkt4b2FrbndSSWxPczd4ajdRZCIsImNsaWVudGlkIjoiZTVjZDdlNDg5MWJmOTVkMWQxOTIwNmNlMjRhN2IzMmUiLCJ0ZW5hbnRJZCI6IjAwMDAwMCIsInVzZXJJZCI6MSwidXNlck5hbWUiOiJhZG1pbiIsImRlcHRJZCI6MTAzLCJkZXB0TmFtZSI6IueglOWPkemDqOmXqCJ9.YuaXPu6eTzJVkLyQC3ekzmPS_jXp50ykaIB2nWy11qM",
"refresh_token": null,
"expire_in": 604799,
"refresh_expire_in": null,
"client_id": "e5cd7e4891bf95d1d19206ce24a7b32e"
}
}
```
|参数名|说明|
|---|---|
|scope| 令牌权限 |
|openid| 用户 openid |
|access_token| 授权令牌 |
|refresh_token| 刷新令牌 |
|expire_in| 授权令牌 access_token 的有效期 |
|refresh_expire_in| 刷新令牌 refresh_token 的有效期 |
|clientId| 客户端id表 sys_client |

View File

@@ -0,0 +1,10 @@
# 实体bean为空问题
- - -
### 问题排查
检查是否存在 `链式调用` 注解 `@Accessors(chain = true)` 删除即可
### 原因
java 规范 set 返回值为 `void` 链式调用 set 返回值为 `this`<br>
故多数框架底层使用 jdk 工具导致找不到 set 方法<br>
例如: `easyexcel` `cglib` `mybatis`

Some files were not shown because too many files have changed in this diff Show More