From 0baeb5d2b147bf29add1e5373652ae70dd749b69 Mon Sep 17 00:00:00 2001
From: ludc
Date: 星期五, 24 三月 2023 21:08:55 +0800
Subject: [PATCH] 更新密码策略功能

---
 Source/BladeX/blade-service/blade-user/src/main/java/org/springblade/system/user/service/impl/UserServiceImpl.java |   58 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 53 insertions(+), 5 deletions(-)

diff --git a/Source/BladeX/blade-service/blade-user/src/main/java/org/springblade/system/user/service/impl/UserServiceImpl.java b/Source/BladeX/blade-service/blade-user/src/main/java/org/springblade/system/user/service/impl/UserServiceImpl.java
index 7465d53..5138b90 100644
--- a/Source/BladeX/blade-service/blade-user/src/main/java/org/springblade/system/user/service/impl/UserServiceImpl.java
+++ b/Source/BladeX/blade-service/blade-user/src/main/java/org/springblade/system/user/service/impl/UserServiceImpl.java
@@ -36,6 +36,7 @@
 import org.springblade.system.cache.DictCache;
 import org.springblade.system.cache.ParamCache;
 import org.springblade.system.cache.SysCache;
+import org.springblade.system.entity.Strategy;
 import org.springblade.system.entity.Tenant;
 import org.springblade.system.enums.DictEnum;
 import org.springblade.system.feign.ISysClient;
@@ -51,11 +52,9 @@
 import org.springblade.system.user.wrapper.UserWrapper;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.DigestUtils;
 
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-import java.util.Objects;
+import java.util.*;
 
 import static org.springblade.common.constant.CommonConstant.DEFAULT_PARAM_PASSWORD;
 
@@ -294,6 +293,7 @@
 
 	@Override
 	public boolean updatePassword(Long userId, String oldPassword, String newPassword, String newPassword1) {
+		String hex = DigestUtil.hex(DigestUtils.md5DigestAsHex((newPassword1).getBytes()));
 		User user = getById(userId);
 		if (!newPassword.equals(newPassword1)) {
 			throw new ServiceException("璇疯緭鍏ユ纭殑纭瀵嗙爜!");
@@ -301,7 +301,21 @@
 		if (!user.getPassword().equals(DigestUtil.hex(oldPassword))) {
 			throw new ServiceException("鍘熷瘑鐮佷笉姝g‘!");
 		}
-		return this.update(Wrappers.<User>update().lambda().set(User::getPassword, DigestUtil.hex(newPassword)).eq(User::getId, userId));
+		//鑾峰彇鐢ㄦ埛閲囩敤鐨勫瘑鐮佺瓥鐣�
+		Strategy strategy = sysClient.getByUserId(userId).getData();
+		String resException = "瀵嗙爜涓繀椤诲惈鏈夈��"+strategy.getCombinationIds()+"銆戜腑鐨勩��"+strategy.getRequiredType()+"銆戠瀵嗙爜缁勫悎鏂瑰紡锛屼笖瀵嗙爜闀垮害蹇呴』鍦ㄣ��"+strategy.getMinPwdLen()+"-"+strategy.getMaxPwdLen()+"銆戣寖鍥村唴";
+		//瀵嗙爜闀垮害鏍¢獙
+		if(newPassword1.length() < strategy.getMinPwdLen() || newPassword1.length() > strategy.getMaxPwdLen()){
+			throw new ServiceException(resException);
+		}
+		//鏌ヨ瀵嗙爜绛栫暐鍙栧��
+		String regex = sysClient.getRegex(Arrays.asList(strategy.getCombinationIds().split(","))).getData();
+		System.out.println("===============regex================"+regex);
+		regex = "^"+regex+"$";
+		String result = RegexUtil.findResult(regex, newPassword);
+		System.out.println(result);
+		return this.update(Wrappers.<User>update().lambda().set(User::getPassword, DigestUtil.hex(DigestUtils.md5DigestAsHex((newPassword1).getBytes()))).eq(User::getId, userId));
+		//return true;
 	}
 
 	@Override
@@ -438,4 +452,38 @@
 		return userVO;
 	}
 
+	@Override
+	public Long checkRenAndExpr(Long userId) {
+		//鑾峰彇鍒板瘑鐮佷慨鏀规椂闂�
+		Date pwdUpdateTime = this.getOne(Wrappers.<User>query().eq("ID", userId)).getPwdUpdateTime();
+		Long pwdupdateday = 0L;
+		if(!Func.isEmpty(pwdUpdateTime)){
+			pwdupdateday = dateToDay(pwdUpdateTime);
+		}
+		Strategy strategy = sysClient.getByUserId(userId).getData();
+		System.out.println("褰撳墠鏃堕棿=================="+dateToDay(new Date()));
+		System.out.println("瀵嗙爜淇敼鏃堕棿======================"+pwdupdateday);
+		System.out.println("鎻愰啋鏃堕棿======================"+strategy.getReminderTime());
+		System.out.println("杩囨湡鏃堕棿======================="+strategy.getExpirationTime());
+		//鏄惁鎻愰啋閫氳繃鏈�鍚庝竴娆′慨鏀瑰瘑鐮佺殑鏃堕棿鍔犱笂杩囨湡鏃堕棿鍑忓幓褰撳墠鏃堕棿锛屽鏋滃皬浜庤繃鏈熸彁閱掓椂闂村氨杩涜鎻愰啋锛屽鏋�<=0灏辨彁閱掑繀椤讳慨鏀瑰瘑鐮�
+		long reminder = pwdupdateday+strategy.getExpirationTime()-dateToDay(pwdUpdateTime);
+		//蹇呴』鍘讳慨鏀瑰瘑鐮�
+		if(reminder<=0){
+			return -1L;
+		}
+		//鎻愰啋鐢ㄦ埛杩樻湁澶氫箙杩囨湡
+		if(reminder<=strategy.getReminderTime()){
+			long res = (strategy.getReminderTime()+pwdupdateday)-dateToDay(new Date());
+			return res;
+		}
+		//浠h〃姝e父鐘舵�佽繕鏈埌鎻愰啋涓庤繃鏈熸椂闂达紝鏃笉鎻愰啋涔熶笉瑕佹眰淇敼
+		return 0L;
+	}
+
+	private Long dateToDay(Date date){
+		long time = date.getTime();
+		return time/(1000 * 60 * 60 * 24);
+	}
+
+
 }

--
Gitblit v1.9.3