From 3a45da15c947c2d478a44a51bd0f926647b1b841 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期五, 11 四月 2025 16:33:17 +0800
Subject: [PATCH] 提交

---
 server/service/src/main/java/com/doumee/config/shiro/ShiroCredentialsMatcher.java |   14 ++++++++++----
 1 files changed, 10 insertions(+), 4 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/config/shiro/ShiroCredentialsMatcher.java b/server/service/src/main/java/com/doumee/config/shiro/ShiroCredentialsMatcher.java
index cde2c50..24ef699 100644
--- a/server/service/src/main/java/com/doumee/config/shiro/ShiroCredentialsMatcher.java
+++ b/server/service/src/main/java/com/doumee/config/shiro/ShiroCredentialsMatcher.java
@@ -26,15 +26,21 @@
     public boolean doCredentialsMatch(AuthenticationToken token, AuthenticationInfo info) {
         ShiroToken usernamePasswordToken = (ShiroToken) token;
         SystemUser queryUserDto = new SystemUser();
-        queryUserDto.setUsername(usernamePasswordToken.getUsername());
         queryUserDto.setDeleted(Boolean.FALSE);
+        if(!usernamePasswordToken.isNeedPassword()){
+            queryUserDto.setMobile(usernamePasswordToken.getUsername());
+            SystemUser systemUser = systemUserService.findOne(queryUserDto);
+            if (systemUser == null) {
+                return Boolean.FALSE;
+            }
+            return Boolean.TRUE;
+        }
+        queryUserDto.setUsername(usernamePasswordToken.getUsername());
         SystemUser systemUser = systemUserService.findOne(queryUserDto);
         if (systemUser == null) {
             return Boolean.FALSE;
         }
-        if(!usernamePasswordToken.isNeedPassword()){
-            return Boolean.TRUE;
-        }
+
         // 鍔犲瘑瀵嗙爜
         String pwd = Utils.Secure.encryptPassword(new String(usernamePasswordToken.getPassword()), systemUser.getSalt());
         // 姣旇緝瀵嗙爜

--
Gitblit v1.9.3