mirror of
https://gitcode.com/ageerle/ruoyi-ai.git
synced 2026-04-09 09:47:32 +00:00
feat(wechat): 修复微信公众号无法登录
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@@ -21,10 +21,13 @@ target/
|
|||||||
|
|
||||||
### IntelliJ IDEA ###
|
### IntelliJ IDEA ###
|
||||||
.idea
|
.idea
|
||||||
|
.claude
|
||||||
|
.github
|
||||||
*.iws
|
*.iws
|
||||||
*.iml
|
*.iml
|
||||||
*.ipr
|
*.ipr
|
||||||
|
|
||||||
|
|
||||||
### JRebel ###
|
### JRebel ###
|
||||||
rebel.xml
|
rebel.xml
|
||||||
|
|
||||||
|
|||||||
23
README.md
23
README.md
@@ -137,6 +137,29 @@
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|
||||||
|
## 📺 视频教程
|
||||||
|
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
|
<table>
|
||||||
|
<tr>
|
||||||
|
<td align="center">
|
||||||
|
<img src="docs/image/dy.png" alt="微信二维码" width="200" height="200"><br>
|
||||||
|
<strong>打开抖音扫一扫</strong><br>
|
||||||
|
<em>获取免费视频教程</em>
|
||||||
|
</td>
|
||||||
|
<td align="center">
|
||||||
|
<img src="docs/image/bibi.png" alt="QQ群二维码" width="200" height="200"><br>
|
||||||
|
<strong>打开B站扫一扫</strong><br>
|
||||||
|
<em>获取免费视频教程</em>
|
||||||
|
</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
|
|
||||||
**[⭐ 点个Star支持一下](https://github.com/ageerle/ruoyi-ai)** • **[ Fork 开始贡献](https://github.com/ageerle/ruoyi-ai/fork)** • **[📚 English](README_EN.md)** • **[📖 查看完整文档](https://doc.pandarobot.chat)**
|
**[⭐ 点个Star支持一下](https://github.com/ageerle/ruoyi-ai)** • **[ Fork 开始贡献](https://github.com/ageerle/ruoyi-ai/fork)** • **[📚 English](README_EN.md)** • **[📖 查看完整文档](https://doc.pandarobot.chat)**
|
||||||
|
|||||||
17
README_EN.md
17
README_EN.md
@@ -1,3 +1,4 @@
|
|||||||
|
|
||||||
# RuoYi AI
|
# RuoYi AI
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
@@ -115,21 +116,7 @@ Thanks to the following excellent open-source projects for their support:
|
|||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
|
|
||||||
<table>
|
**[📱 Join Telegram Group](https://t.me/+LqooQAc5HxRmYmE1)**
|
||||||
<tr>
|
|
||||||
<td align="center">
|
|
||||||
<img src="docs/image/wx.png" alt="WeChat QR Code" width="200" height="200"><br>
|
|
||||||
<strong>Scan to Add Author's WeChat</strong><br>
|
|
||||||
<em>Invitation to join the group</em>
|
|
||||||
</td>
|
|
||||||
<td align="center">
|
|
||||||
<img src="docs/image/qq.png" alt="QQ Group QR Code" width="200" height="200"><br>
|
|
||||||
<strong>QQ Technical Discussion Group</strong><br>
|
|
||||||
<em>Technical discussions</em>
|
|
||||||
</td>
|
|
||||||
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
BIN
docs/image/bibi.png
Normal file
BIN
docs/image/bibi.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 70 KiB |
BIN
docs/image/dy.png
Normal file
BIN
docs/image/dy.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 156 KiB |
4
pom.xml
4
pom.xml
@@ -50,9 +50,9 @@
|
|||||||
<!-- 工作流配置 -->
|
<!-- 工作流配置 -->
|
||||||
<warm-flow.version>1.8.2</warm-flow.version>
|
<warm-flow.version>1.8.2</warm-flow.version>
|
||||||
<!-- 企业微信SDK -->
|
<!-- 企业微信SDK -->
|
||||||
<weixin-java-cp.version>4.4.0</weixin-java-cp.version>
|
<weixin-java-cp.version>4.6.0</weixin-java-cp.version>
|
||||||
<!-- Jackson XML -->
|
<!-- Jackson XML -->
|
||||||
<jackson-dataformat-xml.version>2.20.1</jackson-dataformat-xml.version>
|
<jackson-dataformat-xml.version>2.18.2</jackson-dataformat-xml.version>
|
||||||
<!-- AI 相关依赖 -->
|
<!-- AI 相关依赖 -->
|
||||||
<langchain4j.version>1.11.0</langchain4j.version>
|
<langchain4j.version>1.11.0</langchain4j.version>
|
||||||
<langchain4j.community.version>1.11.0-beta19</langchain4j.community.version>
|
<langchain4j.community.version>1.11.0-beta19</langchain4j.community.version>
|
||||||
|
|||||||
@@ -90,7 +90,7 @@ spring:
|
|||||||
sys:
|
sys:
|
||||||
upload:
|
upload:
|
||||||
path: D:\\DownLoad
|
path: D:\\DownLoad
|
||||||
|
|
||||||
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
|
--- # redis 单机配置(单机与集群只能开启一个另一个需要注释掉)
|
||||||
spring.data:
|
spring.data:
|
||||||
redis:
|
redis:
|
||||||
@@ -268,4 +268,4 @@ justauth:
|
|||||||
client-secret: 1f7d08**********5b7**********29e
|
client-secret: 1f7d08**********5b7**********29e
|
||||||
redirect-uri: ${justauth.address}/social-callback?source=gitea
|
redirect-uri: ${justauth.address}/social-callback?source=gitea
|
||||||
|
|
||||||
AGENT_ALLOWED_TABLES: "abtest_rule,abtest_project,agent_ban_log,agent_ban_logs,agent_install_sub_task,agent_install_sum_task,agent_install_task"
|
AGENT_ALLOWED_TABLES: "abtest_rule,abtest_project,agent_ban_log,agent_ban_logs,agent_install_sub_task,agent_install_sum_task,agent_install_task"
|
||||||
|
|||||||
@@ -125,7 +125,9 @@ security:
|
|||||||
- /*/api-docs/**
|
- /*/api-docs/**
|
||||||
- /warm-flow-ui/config
|
- /warm-flow-ui/config
|
||||||
- /workflow/run
|
- /workflow/run
|
||||||
|
- /user/qrcode
|
||||||
|
- /user/login/qrcode
|
||||||
|
- /weixin/check
|
||||||
# 多租户配置
|
# 多租户配置
|
||||||
tenant:
|
tenant:
|
||||||
# 是否开启
|
# 是否开启
|
||||||
@@ -309,6 +311,7 @@ wechat:
|
|||||||
secret: ''
|
secret: ''
|
||||||
token: ''
|
token: ''
|
||||||
aesKey: ''
|
aesKey: ''
|
||||||
|
|
||||||
--- # Neo4j 知识图谱配置
|
--- # Neo4j 知识图谱配置
|
||||||
neo4j:
|
neo4j:
|
||||||
uri: bolt://117.72.192.162:7687
|
uri: bolt://117.72.192.162:7687
|
||||||
|
|||||||
@@ -15,4 +15,13 @@ public interface ConfigService {
|
|||||||
*/
|
*/
|
||||||
String getConfigValue(String configKey);
|
String getConfigValue(String configKey);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据配置类型和配置key获取值
|
||||||
|
*
|
||||||
|
* @param category 配置类型
|
||||||
|
* @param configKey 配置key
|
||||||
|
* @return 配置属性
|
||||||
|
*/
|
||||||
|
String getConfigValue(String category, String configKey);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,26 +1,27 @@
|
|||||||
package org.ruoyi.controller.chat;
|
package org.ruoyi.system.controller.system;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
import jakarta.servlet.http.HttpServletResponse;
|
|
||||||
import jakarta.validation.constraints.*;
|
|
||||||
import cn.dev33.satoken.annotation.SaCheckPermission;
|
import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||||
import org.ruoyi.common.web.core.BaseController;
|
import jakarta.servlet.http.HttpServletResponse;
|
||||||
import org.ruoyi.service.chat.IChatConfigService;
|
import jakarta.validation.constraints.NotEmpty;
|
||||||
import org.springframework.web.bind.annotation.*;
|
import jakarta.validation.constraints.NotNull;
|
||||||
import org.springframework.validation.annotation.Validated;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.ruoyi.common.idempotent.annotation.RepeatSubmit;
|
|
||||||
import org.ruoyi.common.log.annotation.Log;
|
|
||||||
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
|
||||||
import org.ruoyi.common.core.domain.R;
|
import org.ruoyi.common.core.domain.R;
|
||||||
import org.ruoyi.common.core.validate.AddGroup;
|
import org.ruoyi.common.core.validate.AddGroup;
|
||||||
import org.ruoyi.common.core.validate.EditGroup;
|
import org.ruoyi.common.core.validate.EditGroup;
|
||||||
import org.ruoyi.common.log.enums.BusinessType;
|
|
||||||
import org.ruoyi.common.excel.utils.ExcelUtil;
|
import org.ruoyi.common.excel.utils.ExcelUtil;
|
||||||
import org.ruoyi.domain.vo.chat.ChatConfigVo;
|
import org.ruoyi.common.idempotent.annotation.RepeatSubmit;
|
||||||
import org.ruoyi.domain.bo.chat.ChatConfigBo;
|
import org.ruoyi.common.log.annotation.Log;
|
||||||
|
import org.ruoyi.common.log.enums.BusinessType;
|
||||||
|
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
||||||
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
||||||
|
import org.ruoyi.common.web.core.BaseController;
|
||||||
|
import org.ruoyi.system.domain.bo.ChatConfigBo;
|
||||||
|
import org.ruoyi.system.domain.vo.ChatConfigVo;
|
||||||
|
import org.ruoyi.system.service.IChatConfigService;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置信息
|
* 配置信息
|
||||||
@@ -79,6 +80,25 @@ public class ChatConfigController extends BaseController {
|
|||||||
return toAjax(chatConfigService.insertByBo(bo));
|
return toAjax(chatConfigService.insertByBo(bo));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 新增或者修改配置信息
|
||||||
|
*/
|
||||||
|
@SaCheckPermission("system:config:add")
|
||||||
|
@Log(title = "新增或者修改配置信息", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit()
|
||||||
|
@PostMapping("/saveOrUpdate")
|
||||||
|
public R<Void> saveOrUpdate(@RequestBody List<ChatConfigBo> boList) {
|
||||||
|
for (ChatConfigBo chatConfigBo : boList) {
|
||||||
|
if (chatConfigBo.getId() == null) {
|
||||||
|
chatConfigService.insertByBo(chatConfigBo);
|
||||||
|
} else {
|
||||||
|
chatConfigService.updateByBo(chatConfigBo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return toAjax(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 修改配置信息
|
* 修改配置信息
|
||||||
*/
|
*/
|
||||||
@@ -1,9 +1,12 @@
|
|||||||
package org.ruoyi.domain.entity.chat;
|
package org.ruoyi.system.domain;
|
||||||
|
|
||||||
import org.ruoyi.common.tenant.core.TenantEntity;
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
import com.baomidou.mybatisplus.annotation.*;
|
import com.baomidou.mybatisplus.annotation.TableLogic;
|
||||||
|
import com.baomidou.mybatisplus.annotation.TableName;
|
||||||
|
import com.baomidou.mybatisplus.annotation.Version;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
import org.ruoyi.common.tenant.core.TenantEntity;
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
|
|
||||||
@@ -1,13 +1,14 @@
|
|||||||
package org.ruoyi.domain.bo.chat;
|
package org.ruoyi.system.domain.bo;
|
||||||
|
|
||||||
import org.ruoyi.common.core.validate.AddGroup;
|
|
||||||
import org.ruoyi.common.core.validate.EditGroup;
|
|
||||||
import org.ruoyi.domain.entity.chat.ChatConfig;
|
|
||||||
import org.ruoyi.common.mybatis.core.domain.BaseEntity;
|
|
||||||
import io.github.linpeilie.annotations.AutoMapper;
|
import io.github.linpeilie.annotations.AutoMapper;
|
||||||
|
import jakarta.validation.constraints.NotBlank;
|
||||||
|
import jakarta.validation.constraints.NotNull;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import jakarta.validation.constraints.*;
|
import org.ruoyi.common.core.validate.AddGroup;
|
||||||
|
import org.ruoyi.common.core.validate.EditGroup;
|
||||||
|
import org.ruoyi.common.mybatis.core.domain.BaseEntity;
|
||||||
|
import org.ruoyi.system.domain.ChatConfig;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置信息业务对象 chat_config
|
* 配置信息业务对象 chat_config
|
||||||
@@ -1,16 +1,15 @@
|
|||||||
package org.ruoyi.domain.vo.chat;
|
package org.ruoyi.system.domain.vo;
|
||||||
|
|
||||||
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
|
||||||
import cn.idev.excel.annotation.ExcelProperty;
|
import cn.idev.excel.annotation.ExcelProperty;
|
||||||
import io.github.linpeilie.annotations.AutoMapper;
|
import io.github.linpeilie.annotations.AutoMapper;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.ruoyi.domain.entity.chat.ChatConfig;
|
import org.ruoyi.system.domain.ChatConfig;
|
||||||
|
|
||||||
import java.io.Serial;
|
import java.io.Serial;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置信息视图对象 chat_config
|
* 配置信息视图对象 chat_config
|
||||||
*
|
*
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
package org.ruoyi.mapper.chat;
|
package org.ruoyi.system.mapper;
|
||||||
|
|
||||||
import org.ruoyi.domain.entity.chat.ChatConfig;
|
|
||||||
import org.ruoyi.domain.vo.chat.ChatConfigVo;
|
|
||||||
import org.ruoyi.common.mybatis.core.mapper.BaseMapperPlus;
|
import org.ruoyi.common.mybatis.core.mapper.BaseMapperPlus;
|
||||||
|
import org.ruoyi.system.domain.ChatConfig;
|
||||||
|
import org.ruoyi.system.domain.vo.ChatConfigVo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置信息Mapper接口
|
* 配置信息Mapper接口
|
||||||
@@ -1,9 +1,9 @@
|
|||||||
package org.ruoyi.service.chat;
|
package org.ruoyi.system.service;
|
||||||
|
|
||||||
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
||||||
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
||||||
import org.ruoyi.domain.bo.chat.ChatConfigBo;
|
import org.ruoyi.system.domain.bo.ChatConfigBo;
|
||||||
import org.ruoyi.domain.vo.chat.ChatConfigVo;
|
import org.ruoyi.system.domain.vo.ChatConfigVo;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -1,24 +1,24 @@
|
|||||||
package org.ruoyi.service.chat.impl;
|
package org.ruoyi.system.service.impl;
|
||||||
|
|
||||||
import org.ruoyi.common.core.utils.MapstructUtils;
|
|
||||||
import org.ruoyi.common.core.utils.StringUtils;
|
|
||||||
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
|
||||||
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
|
||||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.ruoyi.service.chat.IChatConfigService;
|
import org.ruoyi.common.core.utils.MapstructUtils;
|
||||||
|
import org.ruoyi.common.core.utils.StringUtils;
|
||||||
|
import org.ruoyi.common.mybatis.core.page.PageQuery;
|
||||||
|
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
||||||
|
import org.ruoyi.system.domain.ChatConfig;
|
||||||
|
import org.ruoyi.system.domain.bo.ChatConfigBo;
|
||||||
|
import org.ruoyi.system.domain.vo.ChatConfigVo;
|
||||||
|
import org.ruoyi.system.mapper.ChatConfigMapper;
|
||||||
|
import org.ruoyi.system.service.IChatConfigService;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.ruoyi.domain.bo.chat.ChatConfigBo;
|
|
||||||
import org.ruoyi.domain.vo.chat.ChatConfigVo;
|
|
||||||
import org.ruoyi.domain.entity.chat.ChatConfig;
|
|
||||||
import org.ruoyi.mapper.chat.ChatConfigMapper;
|
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Collection;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 配置信息Service业务层处理
|
* 配置信息Service业务层处理
|
||||||
@@ -18,9 +18,11 @@ import org.ruoyi.common.mybatis.core.page.PageQuery;
|
|||||||
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
import org.ruoyi.common.mybatis.core.page.TableDataInfo;
|
||||||
import org.ruoyi.common.redis.utils.CacheUtils;
|
import org.ruoyi.common.redis.utils.CacheUtils;
|
||||||
import org.ruoyi.common.tenant.helper.TenantHelper;
|
import org.ruoyi.common.tenant.helper.TenantHelper;
|
||||||
|
import org.ruoyi.system.domain.ChatConfig;
|
||||||
import org.ruoyi.system.domain.SysConfig;
|
import org.ruoyi.system.domain.SysConfig;
|
||||||
import org.ruoyi.system.domain.bo.SysConfigBo;
|
import org.ruoyi.system.domain.bo.SysConfigBo;
|
||||||
import org.ruoyi.system.domain.vo.SysConfigVo;
|
import org.ruoyi.system.domain.vo.SysConfigVo;
|
||||||
|
import org.ruoyi.system.mapper.ChatConfigMapper;
|
||||||
import org.ruoyi.system.mapper.SysConfigMapper;
|
import org.ruoyi.system.mapper.SysConfigMapper;
|
||||||
import org.ruoyi.system.service.ISysConfigService;
|
import org.ruoyi.system.service.ISysConfigService;
|
||||||
import org.springframework.cache.annotation.CachePut;
|
import org.springframework.cache.annotation.CachePut;
|
||||||
@@ -41,6 +43,9 @@ public class SysConfigServiceImpl implements ISysConfigService, ConfigService {
|
|||||||
|
|
||||||
private final SysConfigMapper baseMapper;
|
private final SysConfigMapper baseMapper;
|
||||||
|
|
||||||
|
|
||||||
|
private final ChatConfigMapper configMapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 分页查询参数配置列表
|
* 分页查询参数配置列表
|
||||||
*
|
*
|
||||||
@@ -212,4 +217,12 @@ public class SysConfigServiceImpl implements ISysConfigService, ConfigService {
|
|||||||
return SpringUtils.getAopProxy(this).selectConfigByKey(configKey);
|
return SpringUtils.getAopProxy(this).selectConfigByKey(configKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getConfigValue(String category, String configKey) {
|
||||||
|
ChatConfig config = configMapper.selectOne(new LambdaQueryWrapper<ChatConfig>()
|
||||||
|
.eq(ChatConfig::getCategory, category)
|
||||||
|
.eq(ChatConfig::getConfigName, configKey));
|
||||||
|
return ObjectUtils.notNullGetter(config, ChatConfig::getConfigValue, StringUtils.EMPTY);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,8 +7,10 @@ import cn.hutool.crypto.digest.BCrypt;
|
|||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.apache.commons.lang3.math.NumberUtils;
|
import org.apache.commons.lang3.math.NumberUtils;
|
||||||
import org.ruoyi.common.core.constant.Constants;
|
import org.ruoyi.common.core.constant.Constants;
|
||||||
|
import org.ruoyi.common.core.constant.SystemConstants;
|
||||||
import org.ruoyi.common.core.domain.dto.VisitorLoginUserDto;
|
import org.ruoyi.common.core.domain.dto.VisitorLoginUserDto;
|
||||||
import org.ruoyi.common.core.enums.UserType;
|
import org.ruoyi.common.core.enums.UserType;
|
||||||
|
import org.ruoyi.common.core.exception.ServiceException;
|
||||||
import org.ruoyi.common.core.service.UserLoginService;
|
import org.ruoyi.common.core.service.UserLoginService;
|
||||||
import org.ruoyi.common.core.utils.MessageUtils;
|
import org.ruoyi.common.core.utils.MessageUtils;
|
||||||
import org.ruoyi.common.satoken.utils.LoginHelper;
|
import org.ruoyi.common.satoken.utils.LoginHelper;
|
||||||
@@ -33,12 +35,19 @@ public class UserLoginServiceImpl implements UserLoginService {
|
|||||||
|
|
||||||
|
|
||||||
public VisitorLoginUserDto mpLogin(String openid, String clientId) {
|
public VisitorLoginUserDto mpLogin(String openid, String clientId) {
|
||||||
|
// 校验客户端
|
||||||
|
SysClientVo client = clientService.queryByClientId(clientId);
|
||||||
|
if (ObjectUtil.isNull(client)) {
|
||||||
|
throw new ServiceException(MessageUtils.message("auth.grant.type.error"));
|
||||||
|
} else if (!SystemConstants.NORMAL.equals(client.getStatus())) {
|
||||||
|
throw new ServiceException(MessageUtils.message("auth.grant.type.blocked"));
|
||||||
|
}
|
||||||
// 使用 openid 查询绑定用户 如未绑定用户 则根据业务自行处理 例如 创建默认用户
|
// 使用 openid 查询绑定用户 如未绑定用户 则根据业务自行处理 例如 创建默认用户
|
||||||
SysUserVo user = userService.selectUserByOpenId(openid);
|
SysUserVo user = userService.selectUserByOpenId(openid);
|
||||||
VisitorLoginUserDto loginUser = new VisitorLoginUserDto();
|
VisitorLoginUserDto loginUser = new VisitorLoginUserDto();
|
||||||
if (ObjectUtil.isNull(user)) {
|
if (ObjectUtil.isNull(user)) {
|
||||||
SysUserBo sysUser = new SysUserBo();
|
SysUserBo sysUser = new SysUserBo();
|
||||||
String name = "用户" + UUID.randomUUID().toString().replace("-", "");
|
String name = "用户" + UUID.randomUUID().toString().replace("-", "").substring(0, 7);
|
||||||
// 设置默认用户名
|
// 设置默认用户名
|
||||||
sysUser.setUserName(name);
|
sysUser.setUserName(name);
|
||||||
// 设置默认昵称
|
// 设置默认昵称
|
||||||
@@ -47,6 +56,8 @@ public class UserLoginServiceImpl implements UserLoginService {
|
|||||||
sysUser.setPassword(BCrypt.hashpw("123456"));
|
sysUser.setPassword(BCrypt.hashpw("123456"));
|
||||||
// 设置微信openId
|
// 设置微信openId
|
||||||
sysUser.setOpenId(openid);
|
sysUser.setOpenId(openid);
|
||||||
|
// 设置用户类型
|
||||||
|
sysUser.setUserType(UserType.SYS_USER.getUserType());
|
||||||
// 设置默认余额
|
// 设置默认余额
|
||||||
sysUser.setUserBalance(NumberUtils.toDouble("1"));
|
sysUser.setUserBalance(NumberUtils.toDouble("1"));
|
||||||
// 注册用户,设置默认租户为0
|
// 注册用户,设置默认租户为0
|
||||||
@@ -54,16 +65,15 @@ public class UserLoginServiceImpl implements UserLoginService {
|
|||||||
// 构建登录用户信息
|
// 构建登录用户信息
|
||||||
loginUser.setUserId(sysUser.getUserId());
|
loginUser.setUserId(sysUser.getUserId());
|
||||||
loginUser.setUsername(sysUser.getUserName());
|
loginUser.setUsername(sysUser.getUserName());
|
||||||
loginUser.setUserType(UserType.APP_USER.getUserType());
|
loginUser.setUserType(UserType.SYS_USER.getUserType());
|
||||||
loginUser.setOpenid(openid);
|
loginUser.setOpenid(openid);
|
||||||
} else {
|
} else {
|
||||||
// 此处可根据登录用户的数据不同 自行创建 loginUser
|
// 此处可根据登录用户的数据不同 自行创建 loginUser
|
||||||
loginUser.setUserId(user.getUserId());
|
loginUser.setUserId(user.getUserId());
|
||||||
loginUser.setUsername(user.getUserName());
|
loginUser.setUsername(user.getUserName());
|
||||||
loginUser.setUserType(user.getUserType());
|
loginUser.setUserType(UserType.SYS_USER.getUserType());
|
||||||
loginUser.setOpenid(openid);
|
loginUser.setOpenid(openid);
|
||||||
}
|
}
|
||||||
SysClientVo client = clientService.queryByClientId(clientId);
|
|
||||||
SaLoginParameter model = new SaLoginParameter();
|
SaLoginParameter model = new SaLoginParameter();
|
||||||
model.setDeviceType(client.getDeviceType());
|
model.setDeviceType(client.getDeviceType());
|
||||||
// 自定义分配 不同用户体系 不同 token 授权时间 不设置默认走全局 yml 配置
|
// 自定义分配 不同用户体系 不同 token 授权时间 不设置默认走全局 yml 配置
|
||||||
|
|||||||
@@ -74,6 +74,6 @@ public class WeixinApiUtil {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public String getKey(String key) {
|
public String getKey(String key) {
|
||||||
return configService.getConfigValue("weixin");
|
return configService.getConfigValue("wechat",key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user