沈训 4 weeks ago
parent
commit
869f004311
  1. 49
      .gitee/ISSUE_TEMPLATE.zh-CN.md
  2. 50
      .gitee/ISSUE_TEMPLATE/bug.yml
  3. 5
      .gitee/ISSUE_TEMPLATE/config.yml
  4. 43
      .gitee/ISSUE_TEMPLATE/feature.yml
  5. 7
      .gitee/PULL_REQUEST_TEMPLATE.zh-CN.md
  6. 14
      coin-app/src/main/java/com/coin/app/controller/user/SysProfileController.java
  7. 11
      coin-app/src/main/java/com/coin/app/controller/user/UserPasswdController.java
  8. 19
      coin-app/src/main/resources/application-dev.yml
  9. 2
      coin-common/src/main/java/com/coin/common/core/domain/entity/SysUser.java
  10. 1
      coin-common/src/main/java/com/coin/common/core/domain/model/LoginBody.java
  11. 28
      coin-common/src/main/java/com/coin/common/core/domain/model/PasswordBody.java
  12. 2
      coin-common/src/main/java/com/coin/common/utils/RSA/RSATest.java
  13. 2
      coin-demo/src/main/java/com/coin/demo/domain/vo/ExportDemoVo.java
  14. 14
      coin-system/src/main/java/com/coin/app/service/impl/AtomOperationServiceImpl.java
  15. 75
      coin-system/src/main/java/com/coin/app/service/impl/TransactionRecordServiceImpl.java
  16. 5
      coin-system/src/main/java/com/coin/business/service/IUserPasswdService.java
  17. 35
      coin-system/src/main/java/com/coin/business/service/impl/UserCardServiceImpl.java
  18. 36
      coin-system/src/main/java/com/coin/business/service/impl/UserPasswdServiceImpl.java
  19. 4
      coin-system/src/main/java/com/coin/system/service/SysRegisterService.java
  20. 65
      coin-system/src/main/resources/mapper/business/RecordTransactionMapper.xml
  21. 2393
      script/sql/ry_vue-3-6.sql

49
.gitee/ISSUE_TEMPLATE.zh-CN.md

@ -1,49 +0,0 @@
### 使用版本(未按照模板填写直接删除)
- jdk版本(带上尾号): 例如 1.8.0_202
- 框架版本(项目启动时输出的版本号): 例如 4.4.0
- 其他依赖版本(你觉得有必要的):
### 问题前提
> 功能不好用 不会用 是否已经看过项目文档
> 项目运行报错 是否已经拿着报错信息去百度 常见报错百度百度足以
> 是否搜索过其他issue 一些已经解决的问题 会在issue内留下解决方法
> 无法线上解决或者与框架无关的问题的欢迎加VIP群跟作者一对一谈
### 异常模块
> 此报错都涉及到那些系统模块
例如 ruoyi-system ruoyi-auth 等等
### 问题描述
> 越详细越容易直击问题所在
已知: XXX功能不好用 或 XXX数据不正常 等等
### 希望结果
> 想知道你觉得怎么样是正常或者合理的
希望功能可以有XXX结果 或者 XXX现象
### 重现步骤
> 作者并不知道这个问题是如何出现的
- 1
- 2
- 3
### 相关代码与报错信息(请勿发混乱格式)
> 代码可按照如下形式提供或者截图均可 越详细越好
> 大多数问题都是 代码编写错误问题 逻辑问题 或者用法错误等问题
```java
public class XXX {
}
```

50
.gitee/ISSUE_TEMPLATE/bug.yml

@ -1,50 +0,0 @@
name: Bug 反馈
description: 当你中发现了一个 Bug,导致应用崩溃或抛出异常,或者有一个组件存在问题,或者某些地方看起来不对劲。
title: "[Bug]: "
labels: ["bug"]
body:
- type: textarea
id: version
attributes:
label: 版本
description: 你当前正在使用我们软件的哪个版本(pom文件内的版本号)?
value: |
jdk版本(带上尾号): 例如 1.8.0
框架版本(项目启动时输出的版本号): 例如 4.4.0
其他依赖版本(你觉得有必要的):
validations:
required: true
- type: checkboxes
attributes:
label: 功能不好用不会用是否已经看过项目文档?
options:
- label: https://plus-doc.dromara.org
required: true
- type: checkboxes
attributes:
label: 这个问题是否已经存在?
options:
- label: 我已经搜索过现有的问题 (https://gitee.com/dromara/RuoYi-Vue-Plus/issues)
required: true
- type: textarea
attributes:
label: 希望结果
description: 想知道你觉得怎么样是正常或者合理的。
validations:
required: true
- type: markdown
attributes:
label: 如何复现
description: 请详细告诉我们如何复现你遇到的问题
value: |
如涉及代码 可提供一个最小代码示例 并使用```附上它 或者截图均可 越详细越好<br>
大多数问题都是 代码编写错误问题 逻辑问题 或者用法错误等问题
validations:
required: true
- type: textarea
attributes:
label: 相关代码与报错信息(请勿发混乱格式)
description: 如果可以的话,上传任何关于 bug 的截图。
value: |
[在这里上传图片]

5
.gitee/ISSUE_TEMPLATE/config.yml

@ -1,5 +0,0 @@
blank_issues_enabled: false
contact_links:
- name: RuoYi-Vue-Plus 文档中心
url: https://plus-doc.dromara.org
about: 提供 RuoYi-Vue-Plus 搭建使用指南、平台基本开发使用方式、介绍、基础知识和常见问题解答

43
.gitee/ISSUE_TEMPLATE/feature.yml

@ -1,43 +0,0 @@
name: 功能建议
description: 对本项目提出一个功能建议
title: "[功能建议]: "
labels: ["enhancement"]
body:
- type: markdown
attributes:
value: |
感谢提出功能建议,我们将仔细考虑!请持续关注该issues,在加入计划后我们会有贡献者设置为负责人,同时状态成为进行中。
- type: textarea
id: related-problem
attributes:
label: 你的功能建议是否和某个问题相关?
description: 清晰并简洁地描述问题是什么,例如,当我...时,我总是感到困扰。
validations:
required: false
- type: textarea
id: desired-solution
attributes:
label: 你希望看到什么解决方案?
description: 清晰并简洁地描述你希望发生的事情。
validations:
required: true
- type: textarea
id: alternatives
attributes:
label: 你考虑过哪些替代方案?
description: 清晰并简洁地描述你考虑过的任何替代解决方案或功能。
validations:
required: false
- type: textarea
id: additional-context
attributes:
label: 你有其他上下文或截图吗?
description: 在此处添加有关功能请求的任何其他上下文或截图。
validations:
required: false
- type: checkboxes
attributes:
label: 意向参与贡献
options:
- label: 我有意向参与具体功能的开发实现并将代码贡献回到上游社区
required: false

7
.gitee/PULL_REQUEST_TEMPLATE.zh-CN.md

@ -1,7 +0,0 @@
### 更改目的 解决了什么问题(请提交到dev分支)
### 改动逻辑 这么写的思路(让作者更好的理解你的意图)
### 测试 都做了哪些测试(未经过测试不采纳)

14
coin-app/src/main/java/com/coin/app/controller/user/SysProfileController.java

@ -6,6 +6,7 @@ import com.coin.common.annotation.Log;
import com.coin.common.core.controller.BaseController;
import com.coin.common.core.domain.R;
import com.coin.common.core.domain.entity.SysUser;
import com.coin.common.core.domain.model.PasswordBody;
import com.coin.common.enums.BusinessType;
import com.coin.common.exception.ServiceException;
import com.coin.common.helper.LoginHelper;
@ -76,24 +77,21 @@ public class SysProfileController extends BaseController {
/**
* 重置密码
*
* @param newPassword 新密码
* @param oldPassword 旧密码
*/
@Log(title = "个人信息", businessType = BusinessType.UPDATE)
@PutMapping("/updatePwd")
public R<Void> updatePwd(String oldPassword, String newPassword) {
@PostMapping("/updatePwd")
public R<Void> updatePwd(@RequestBody PasswordBody body) {
SysUser user = userService.selectUserById(LoginHelper.getUserId());
String userName = user.getUserName();
String password = user.getPassword();
if (!BCrypt.checkpw(oldPassword, password)) {
if (!BCrypt.checkpw(body.getOldPassword(), password)) {
return R.fail("修改密码失败,旧密码错误");
}
if (BCrypt.checkpw(newPassword, password)) {
if (BCrypt.checkpw(body.getNewPassword(), password)) {
return R.fail("新密码不能与旧密码相同");
}
if (userService.resetUserPwd(userName, BCrypt.hashpw(newPassword)) > 0) {
if (userService.resetUserPwd(userName, BCrypt.hashpw(body.getNewPassword())) > 0) {
return R.ok();
}
return R.fail("修改密码异常,请联系管理员");

11
coin-app/src/main/java/com/coin/app/controller/user/UserPasswdController.java

@ -13,6 +13,7 @@ import com.coin.common.core.page.TableDataInfo;
import com.coin.common.core.validate.AddGroup;
import com.coin.common.core.validate.EditGroup;
import com.coin.common.enums.BusinessType;
import com.coin.common.helper.LoginHelper;
import com.coin.common.utils.poi.ExcelUtil;
import lombok.RequiredArgsConstructor;
import org.springframework.validation.annotation.Validated;
@ -56,6 +57,16 @@ public class UserPasswdController extends BaseController {
return R.ok(iUserPasswdService.checkPwd(bo));
}
/**
* 验证有无支付密码
*/
// @SaCheckPermission("business:userPasswd:query")
@GetMapping("/haveOrNotPayPwd")
public R<Void> haveOrNotPayPwd() {
Long userId = LoginHelper.getUserId();
return toAjax(iUserPasswdService.haveOrNotPayPwd(userId));
}
/**
* 导出用户密码列表
*/

19
coin-app/src/main/resources/application-dev.yml

@ -49,17 +49,22 @@ spring:
driverClassName: com.mysql.cj.jdbc.Driver
# jdbc 所有参数配置参考 https://lionli.blog.csdn.net/article/details/122018562
# rewriteBatchedStatements=true 批处理优化 大幅提升批量插入更新删除性能(对数据库有性能损耗 使用批量操作应考虑性能问题)
url: jdbc:mysql://192.168.0.160:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
# url: jdbc:mysql://192.168.0.160:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
url: jdbc:mysql://localhost:3306/ry_vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
username: root
password: admin@Passw0rd
# password: admin@Passw0rd
password: 199911
# 从库数据源
slave:
lazy: true
type: ${spring.datasource.type}
driverClassName: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.0.160:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
# url: jdbc:mysql://192.168.0.160:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
url: jdbc:mysql://localhost:3306/ry_vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&autoReconnect=true&rewriteBatchedStatements=true
username: root
password: admin@Passw0rd
password: 199911
# password: admin@Passw0rd
# oracle:
# type: ${spring.datasource.type}
# driverClassName: oracle.jdbc.OracleDriver
@ -98,13 +103,15 @@ spring:
spring:
redis:
# 地址
host: 192.168.0.160
# host: 192.168.0.160
# host: localhost
host: 192.168.0.34
# 端口,默认为6379
port: 6379
# 数据库索引
database: 0
# 密码(如没有密码请注释掉)
password: 123456
# password: 123456
# 连接超时时间
timeout: 10s
# 是否开启ssl

2
coin-common/src/main/java/com/coin/common/core/domain/entity/SysUser.java

@ -45,7 +45,7 @@ public class SysUser extends BaseEntity {
* 用户账号
*/
@Xss(message = "用户账号不能包含脚本字符")
@NotBlank(message = "用户账号不能为空")
// @NotBlank(message = "用户账号不能为空")
@Size(min = 0, max = 30, message = "用户账号长度不能超过{max}个字符")
private String userName;

1
coin-common/src/main/java/com/coin/common/core/domain/model/LoginBody.java

@ -42,5 +42,6 @@ public class LoginBody {
/**
* 手机号
*/
// @NotBlank(message = "{user.phone.not.blank}")
private String phone;
}

28
coin-common/src/main/java/com/coin/common/core/domain/model/PasswordBody.java

@ -0,0 +1,28 @@
package com.coin.common.core.domain.model;
import com.coin.common.constant.UserConstants;
import lombok.Data;
import org.hibernate.validator.constraints.Length;
import javax.validation.constraints.NotBlank;
/**
* 用户登录对象
*
* @author Lion Li
*/
@Data
public class PasswordBody {
/**
* 老密码
*/
private String oldPassword;
/**
* 新密码
*/
private String newPassword;
}

2
coin-common/src/main/java/com/coin/common/utils/RSA/RSATest.java

@ -27,7 +27,7 @@ public class RSATest {
}
public static void jm_test() throws Exception {
String code = "2552359874125632";
String code = "111111";
String encrypt = RSAComparator.encrypt(code);
boolean compare = RSAComparator.compare(code, encrypt);

2
coin-demo/src/main/java/com/coin/demo/domain/vo/ExportDemoVo.java

@ -33,7 +33,7 @@ public class ExportDemoVo {
* 用户昵称
*/
@ExcelProperty(value = "用户名", index = 0)
@NotEmpty(message = "用户名不能为空", groups = AddGroup.class)
// @NotEmpty(message = "用户名不能为空", groups = AddGroup.class)
private String nickName;
/**

14
coin-system/src/main/java/com/coin/app/service/impl/AtomOperationServiceImpl.java

@ -156,7 +156,7 @@ public class AtomOperationServiceImpl implements IAtomOperationService {
* 原子操作核心封装
*/
@Transactional(rollbackFor = Exception.class)
R<Object> innerOperation(String fromId, String fromAccount, String toId, String toAccount, Double amount, String billCode) {
public R<Object> innerOperation(String fromId, String fromAccount, String toId, String toAccount, Double amount, String billCode) {
try {
// 1. TODO
@ -195,6 +195,13 @@ public class AtomOperationServiceImpl implements IAtomOperationService {
throw new ServiceException("收款方账户已被冻结");
}
BigDecimal fromPreviousAmount = fromUserAccount.getAccountAmount();
BigDecimal fromCurrentAmount = fromUserAccount.getAccountAmount().subtract(BigDecimal.valueOf(amount));
BigDecimal toPreviousAmount = toUserAccount.getAccountAmount();
BigDecimal toCurrentAmount = toUserAccount.getAccountAmount().add(BigDecimal.valueOf(amount));
// 更新付款方账户余额
fromUserAccount.setAccountAmount(fromUserAccount.getAccountAmount().subtract(BigDecimal.valueOf(amount)));
if (userAccountMapper.updateById(fromUserAccount) <= 0) {
@ -207,8 +214,6 @@ public class AtomOperationServiceImpl implements IAtomOperationService {
throw new ServiceException("更新收款方账户余额失败");
}
BigDecimal fromPreviousAmount = fromUserAccount.getAccountAmount();
BigDecimal fromCurrentAmount = fromUserAccount.getAccountAmount().subtract(BigDecimal.valueOf(amount));
// 5. 创建付款方动账记录
RecordTransaction fromRecord = new RecordTransaction();
@ -225,9 +230,6 @@ public class AtomOperationServiceImpl implements IAtomOperationService {
fromRecord.setTime(new Date());
fromRecord.setStatus("1"); // 成功状态
BigDecimal toPreviousAmount = toUserAccount.getAccountAmount();
BigDecimal toCurrentAmount = toUserAccount.getAccountAmount().add(BigDecimal.valueOf(amount));
// 6. 创建收款方动账记录
RecordTransaction toRecord = new RecordTransaction();

75
coin-system/src/main/java/com/coin/app/service/impl/TransactionRecordServiceImpl.java

@ -53,12 +53,26 @@ public class TransactionRecordServiceImpl implements ITransactionRecordService {
if (time != null) {
record.setTimeStr(dateFormat.format(time)); // 假设RecordTransactionVo中有一个String类型的timeStr字段来存储格式化后的时间
}
if (search.getId().equals(record.getSenderId())) { // 收款
record.setRemark(record.getReceiverName() + "向你转账 " + record.getChangeBalance());
} else if (search.getId().equals(record.getReceiverId())) { // 付款
record.setRemark("你向" + record.getSenderName() + "转账 " + record.getChangeBalance());
record.setChangeBalance(record.getChangeBalance() * -1);
if (record.getType() != null){
String type = record.getType().substring(0,2);
String description = BusinessCodeUtils.getDescription(BusinessCodeUtils.BusinessType.valueOf(type));
record.setTypeStr(description);
String s = returnRemark(record.getType(), record.getReceiverAccount().substring(record.getReceiverAccount().length() - 4), record.getReceiverName());
record.setRemark(s);
}
// if (record.getChangeBalance() < 0){
// record.setChangeBalance(record.getChangeBalance() * -1);
// }
// if (search.getId().equals(record.getSenderId())) { // 收款
// record.setRemark(record.getReceiverName() + "向你转账 " + record.getChangeBalance());
// } else if (search.getId().equals(record.getReceiverId())) { // 付款
// record.setRemark("你向" + record.getSenderName() + "转账 " + record.getChangeBalance());
// record.setChangeBalance(record.getChangeBalance() * -1);
// }
}
return resList;
@ -79,28 +93,59 @@ public class TransactionRecordServiceImpl implements ITransactionRecordService {
LocalDate endDate = startDate.withDayOfMonth(startDate.lengthOfMonth());
search.setStart(Date.from(startDate.atStartOfDay(ZoneId.systemDefault()).toInstant()));
search.setEnd(Date.from(endDate.atTime(23, 59, 59).atZone(ZoneId.systemDefault()).toInstant()));
// System.out.println("startDate = " + startDate);
// System.out.println("endDate = " + endDate);
}
Page<RecordTransactionVo> resList = recordTransactionMapper.getRecordList(pageQuery.build(), search);
List<RecordTransactionVo> records = resList.getRecords();
for (RecordTransactionVo record : records) {
if (record.getType() != null) {
String type = record.getType();
// if (search.getId().equals(record.getSenderId())) { // 收款
// record.setRemark(record.getReceiverName() + "向你转账 " + record.getChangeBalance());
// } else if (search.getId().equals(record.getReceiverId())) { // 付款
// record.setRemark("你向" + record.getSenderName() + "转账 " + record.getChangeBalance());
// record.setChangeBalance(record.getChangeBalance() * -1);
// }
if (record.getType() != null){
String type = record.getType().substring(0,2);
String description = BusinessCodeUtils.getDescription(BusinessCodeUtils.BusinessType.valueOf(type));
record.setTypeStr(description);
String s = returnRemark(record.getType(), record.getReceiverAccount().substring(record.getReceiverAccount().length() - 4), record.getReceiverName());
record.setRemark(s);
}
// if (record.getChangeBalance() < 0){
// record.setChangeBalance(record.getChangeBalance() * -1);
// }
if (search.getId().equals(record.getSenderId())) { // 收款
record.setRemark(record.getReceiverName() + "向你转账 " + record.getChangeBalance());
} else if (search.getId().equals(record.getReceiverId())) { // 付款
record.setRemark("你向" + record.getSenderName() + "转账 " + record.getChangeBalance());
record.setChangeBalance(record.getChangeBalance() * -1);
}
}
resList.setRecords(records);
return TableDataInfo.build(resList);
}
/**
* 返回备注
*/
public String returnRemark(String type,String cardNum,String toAccountName){
switch (type) {
case "BU+":
case "BU-":
return "零钱充值-来自银行卡("+cardNum+")";
case "BR+":
case "BR-":
return "收款-来自"+toAccountName;
case "BC+":
case "BC-":
return "零钱提现-到银行卡("+cardNum+")";
case "BP+":
case "BP-":
return "付款-给"+toAccountName;
case "BT+":
return "转账-来自"+toAccountName;
case "BT-":
return "转账-给"+toAccountName;
default:
return "未知";
}
}
}

5
coin-system/src/main/java/com/coin/business/service/IUserPasswdService.java

@ -57,4 +57,9 @@ public interface IUserPasswdService {
* 根据用户id更新密码
*/
Boolean updateByUserId(UserPasswdBo bo);
/**
* 验证有无支付密码
*/
Boolean haveOrNotPayPwd(Long userId);
}

35
coin-system/src/main/java/com/coin/business/service/impl/UserCardServiceImpl.java

@ -1,6 +1,8 @@
package com.coin.business.service.impl;
import cn.hutool.core.bean.BeanUtil;
import com.coin.business.domain.UserAccount;
import com.coin.business.mapper.UserAccountMapper;
import com.coin.common.core.domain.R;
import com.coin.common.core.page.TableDataInfo;
import com.coin.common.core.domain.PageQuery;
@ -17,11 +19,9 @@ import com.coin.business.domain.vo.UserCardVo;
import com.coin.business.domain.UserCard;
import com.coin.business.mapper.UserCardMapper;
import com.coin.business.service.IUserCardService;
import org.springframework.transaction.annotation.Transactional;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Collection;
import java.util.*;
/**
* 用户银行卡Service业务层处理
@ -34,6 +34,7 @@ import java.util.Collection;
public class UserCardServiceImpl implements IUserCardService {
private final UserCardMapper baseMapper;
private final UserAccountMapper userAccountMapper;
/**
* 查询用户银行卡
@ -90,6 +91,7 @@ public class UserCardServiceImpl implements IUserCardService {
* 新增用户银行卡
*/
@Override
@Transactional
public R<Void> insertByBo(UserCardBo bo) {
UserCard add = BeanUtil.toBean(bo, UserCard.class);
List<UserCardVo> userCardVo = selectUserBankCard(bo);
@ -103,10 +105,18 @@ public class UserCardServiceImpl implements IUserCardService {
// 加密
add.setCardNum(RSAComparator.encrypt(add.getCardNum()));
validEntityBeforeSave(add);
boolean flag = baseMapper.insert(add) > 0;
if (flag) {
UserAccount userAccount = buildAccount(bo);
int insert = userAccountMapper.insert(userAccount);
int insert1 = baseMapper.insert(add);
if(insert <= 0 || insert1 <= 0){
return R.fail("系统出错,联系管理员");
}else{
bo.setId(add.getId());
}
// boolean flag = baseMapper.insert(add) > 0;
// if (flag) {
// bo.setId(add.getId());
// }
return R.ok();
}
@ -163,4 +173,17 @@ public class UserCardServiceImpl implements IUserCardService {
lqw.eq(StringUtils.isNotBlank(bo.getUserId()), UserCard::getUserId, bo.getUserId());
return baseMapper.selectVoList(lqw);
}
public UserAccount buildAccount(UserCardBo vo){
UserAccount account = new UserAccount();
account.setAccountId(vo.getCardNum());
account.setAccountName(vo.getBankName());
account.setAccountAmount(vo.getCardAmount());
account.setUserId(vo.getUserId());
account.setCreateBy(vo.getUserId());
account.setCreateTime(new Date());
account.setUpdateBy(vo.getUserId());
account.setUpdateTime(new Date());
return account;
}
}

36
coin-system/src/main/java/com/coin/business/service/impl/UserPasswdServiceImpl.java

@ -70,6 +70,22 @@ public class UserPasswdServiceImpl implements IUserPasswdService {
return false;
}
/**
* 验证有无支付密码
*/
@Override
public Boolean haveOrNotPayPwd(Long userId) {
UserPasswdBo userPasswdBo = new UserPasswdBo();
userPasswdBo.setUserId(String.valueOf(userId));
List<UserPasswd> byUserId = getByUserId(userPasswdBo);
for (UserPasswd vo : byUserId) {
if (vo.getPayPasswd().equals("0")){
return false;
}
}
return true;
}
/**
* 查询用户密码列表
*/
@ -148,16 +164,36 @@ public class UserPasswdServiceImpl implements IUserPasswdService {
return baseMapper.deleteBatchIds(ids) > 0;
}
/**
* 根据用户ID查询用户密码信息列表
*
* @param bo 业务对象包含查询条件参数要求至少包含userId字段用于查询
* 当userId不为空时作为查询条件为空时不加入查询条件
* @return 符合查询条件的用户密码vo实体列表当无匹配记录时返回空列表
*/
private List<UserPasswdVo> selectByUserId(UserPasswdBo bo) {
LambdaQueryWrapper<UserPasswd> lqw = Wrappers.lambdaQuery();
lqw.eq(StringUtils.isNotBlank(bo.getUserId()), UserPasswd::getUserId, bo.getUserId());
return baseMapper.selectVoList(lqw);
}
/**
* 根据用户ID查询用户密码信息列表
*
* @param bo 业务对象包含查询条件参数要求至少包含userId字段用于查询
* 当userId不为空时作为查询条件为空时不加入查询条件
* @return 符合查询条件的用户密码实体列表当无匹配记录时返回空列表
*/
private List<UserPasswd> getByUserId(UserPasswdBo bo) {
// 构建Lambda查询条件包装器
LambdaQueryWrapper<UserPasswd> lqw = Wrappers.lambdaQuery();
// 动态添加查询条件:当传入的userId非空时,添加userId等值查询条件
lqw.eq(StringUtils.isNotBlank(bo.getUserId()), UserPasswd::getUserId, bo.getUserId());
// 执行数据库查询并返回结果列表
return baseMapper.selectList(lqw);
}
}

4
coin-system/src/main/java/com/coin/system/service/SysRegisterService.java

@ -43,7 +43,7 @@ public class SysRegisterService {
*/
@Transactional(rollbackFor = Exception.class) // 添加在方法或类上
public SysUser appRegister(RegisterBody registerBody) {
String username = registerBody.getUsername();
String username = registerBody.getPhone();
String password = registerBody.getPassword();
String phone = registerBody.getPhone();
// 校验用户类型是否存在
@ -59,7 +59,7 @@ public class SysRegisterService {
sysUser.setNickName("U-"+ UniqueCodeGenerator.generateHighConcurrencyCode());
sysUser.setPassword(BCrypt.hashpw(password));
sysUser.setUserType(userType);
sysUser.setPhonenumber(phone);
if (!userService.checkUserNameUnique(sysUser)) {
throw new UserException("用户名已存在!", username);

65
coin-system/src/main/resources/mapper/business/RecordTransactionMapper.xml

@ -26,20 +26,19 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
</resultMap>
<!-- GROUP BY bill_code -->
<!-- 转账 -->
<select id="selectLastTransactionRecord" resultType="com.coin.business.domain.vo.RecordTransactionVo">
SELECT a.*,b.nick_name sender_name,c.nick_name receiver_name from(
SELECT *
from t_record_transaction
SELECT a.*,b.nick_name sender_name,c.nick_name receiver_name
from(
SELECT a.*
from t_record_transaction a
left join t_user_account b on a.sender_account = b.account_id
<where>
<if test="search.id != null and search.id != ''">
and (sender_id = #{search.id} or receiver_id = #{search.id})
</if>
sender_id = 1 and type like 'BT%'
<if test="search.key != null and search.key != ''">
and (
sender_account like concat('%', #{search.key}, '%')
or receiver_account like concat('%', #{search.key}, '%')
or note like concat('%', #{search.key}, '%')
sender_account like concat('%', #{search.key}, '%')
or receiver_account like concat('%', #{search.key}, '%')
)
</if>
<if test="search.start != null">
@ -49,19 +48,22 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
and time &lt;= #{search.end}
</if>
</where>
GROUP BY bill_code
order by time desc
limit 10
) a LEFT JOIN sys_user b on a.sender_id = b.user_id
LEFT JOIN sys_user c on a.receiver_id = c.user_id
where change_balance > 0
GROUP BY bill_code
order by time desc limit 10
LEFT JOIN sys_user c on a.receiver_id = c.user_id
</select>
<select id="getRecordList" resultType="com.coin.business.domain.vo.RecordTransactionVo">
SELECT a.*,b.nick_name sender_name,c.nick_name receiver_name from(
SELECT *
from t_record_transaction
SELECT a.*,b.nick_name sender_name,c.nick_name receiver_name
from(
SELECT a.*
from t_record_transaction a
left join t_user_account b on a.sender_account = b.account_id
<where>
(sender_id = #{search.id} or receiver_id = #{search.id})
sender_id = 1 and is_primary = 1
<if test="search.key != null and search.key != ''">
and (
sender_account like concat('%', #{search.key}, '%')
@ -75,11 +77,34 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
and time &lt;= #{search.end}
</if>
</where>
GROUP BY bill_code
order by time desc
) a LEFT JOIN sys_user b on a.sender_id = b.user_id
LEFT JOIN sys_user c on a.receiver_id = c.user_id
where change_balance > 0
GROUP BY bill_code
</select>
<!-- SELECT a.*,b.nick_name sender_name,c.nick_name receiver_name from(-->
<!-- SELECT *-->
<!-- from t_record_transaction-->
<!-- <where>-->
<!-- (sender_id = #{search.id} or receiver_id = #{search.id})-->
<!-- <if test="search.key != null and search.key != ''">-->
<!-- and (-->
<!-- sender_account like concat('%', #{search.key}, '%')-->
<!-- or receiver_account like concat('%', #{search.key}, '%')-->
<!-- )-->
<!-- </if>-->
<!-- <if test="search.start != null">-->
<!-- and time &gt;= #{search.start}-->
<!-- </if>-->
<!-- <if test="search.end != null">-->
<!-- and time &lt;= #{search.end}-->
<!-- </if>-->
<!-- </where>-->
<!-- ) a LEFT JOIN sys_user b on a.sender_id = b.user_id-->
<!-- LEFT JOIN sys_user c on a.receiver_id = c.user_id-->
<!-- where change_balance > 0-->
<!-- GROUP BY bill_code-->
<!-- order by time desc-->
</mapper>

2393
script/sql/ry_vue-3-6.sql

File diff suppressed because it is too large
Loading…
Cancel
Save