feat(wechat): 修复微信公众号无法登录

This commit is contained in:
ageerle
2026-03-09 10:27:53 +08:00
parent 84dbc2cfbf
commit e601eb6db5
19 changed files with 142 additions and 71 deletions

3
.gitignore vendored
View File

@@ -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

View File

@@ -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)**

View File

@@ -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

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 KiB

BIN
docs/image/dy.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 156 KiB

View File

@@ -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>

View File

@@ -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"

View File

@@ -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

View File

@@ -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);
} }

View File

@@ -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);
}
/** /**
* 修改配置信息 * 修改配置信息
*/ */

View File

@@ -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;

View File

@@ -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

View File

@@ -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
* *

View File

@@ -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接口

View File

@@ -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;

View File

@@ -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业务层处理

View File

@@ -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);
}
} }

View File

@@ -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 配置

View File

@@ -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);
} }
} }