From 9be62968a2b65149e83dd8f9ca20f0b5a60fea96 Mon Sep 17 00:00:00 2001
From: zqy <2522236926@qq.com>
Date: 星期日, 22 六月 2025 23:17:28 +0800
Subject: [PATCH] 修改用户账号的状态 新增一个3 代表账号异常

---
 ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/SysLoginService.java |   84 ++++++++++++++++++++++++++++++++++++------
 1 files changed, 72 insertions(+), 12 deletions(-)

diff --git a/ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/SysLoginService.java b/ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/SysLoginService.java
index 63adb21..58be3dd 100644
--- a/ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/SysLoginService.java
+++ b/ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/SysLoginService.java
@@ -3,6 +3,7 @@
 import javax.annotation.Resource;
 
 import com.ruoyi.domain.SysUserRole1;
+import com.ruoyi.framework.web.domain.server.Sys;
 import com.ruoyi.service.ZfRegisterService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.authentication.AuthenticationManager;
@@ -58,19 +59,8 @@
     @Autowired
     private ZfRegisterService registerService;
 
-    /**
-     * 鐧诲綍楠岃瘉
-     * 
-     * @param username 鐢ㄦ埛鍚�
-     * @param password 瀵嗙爜
-     * @param code 楠岃瘉鐮�
-     * @param uuid 鍞竴鏍囪瘑
-     * @return 缁撴灉
-     */
-    public String login(String username, String password, String code, String uuid)
+    public String loginWithoutValidate(String username, String password)
     {
-        // 楠岃瘉鐮佹牎楠�
-        validateCaptcha(username, code, uuid);
         // 鐧诲綍鍓嶇疆鏍¢獙
         loginPreCheck(username, password);
         // 鐢ㄦ埛楠岃瘉
@@ -105,6 +95,73 @@
 
 
         SysUser sysUser = userService.selectUserByUserName(username);
+        Long userId = sysUser.getUserId();
+        // 鐢熸垚token
+        String token = tokenService.createToken(loginUser);
+
+        SysUserRole1 sysUserRole = registerService.selectUserRole(userId);
+        if(sysUserRole==null){
+            //濡傛灉鐢ㄦ埛杩樻病鏈夎璧嬩簣瑙掕壊锛岄偅灏辩粰涓�涓粯璁ゆ槸瀹跺涵鎴愬憳鐨勮鑹�
+            registerService.setRoleToUser(userId, 102L);
+        }
+        return token;
+    }
+
+
+
+
+
+
+
+    /**
+     * 鐧诲綍楠岃瘉
+     * 
+     * @param nickName 鐢ㄦ埛鍚�
+     * @param password 瀵嗙爜
+     * @param code 楠岃瘉鐮�
+     * @param uuid 鍞竴鏍囪瘑
+     * @return 缁撴灉
+     */
+    public String login(String nickName, String password, String code, String uuid)
+    {
+        // 楠岃瘉鐮佹牎楠�
+        validateCaptcha(nickName, code, uuid);
+        // 鐧诲綍鍓嶇疆鏍¢獙
+        loginPreCheck(nickName, password);
+        // 鐢ㄦ埛楠岃瘉
+        Authentication authentication = null;
+        try
+        {
+            UsernamePasswordAuthenticationToken authenticationToken = new UsernamePasswordAuthenticationToken(nickName, password);
+            AuthenticationContextHolder.setContext(authenticationToken);
+            // 璇ユ柟娉曚細鍘昏皟鐢║serDetailsServiceImpl.loadUserByUsername
+            authentication = authenticationManager.authenticate(authenticationToken);
+        }
+        catch (Exception e)
+        {
+            if (e instanceof BadCredentialsException)
+            {
+                AsyncManager.me().execute(AsyncFactory.recordLogininfor(nickName, Constants.LOGIN_FAIL, MessageUtils.message("user.password.not.match")));
+                throw new UserPasswordNotMatchException();
+            }
+            else
+            {
+                AsyncManager.me().execute(AsyncFactory.recordLogininfor(nickName, Constants.LOGIN_FAIL, e.getMessage()));
+                throw new ServiceException(e.getMessage());
+            }
+        }
+        finally
+        {
+            AuthenticationContextHolder.clearContext();
+        }
+        AsyncManager.me().execute(AsyncFactory.recordLogininfor(nickName, Constants.LOGIN_SUCCESS, MessageUtils.message("user.login.success")));
+        LoginUser loginUser = (LoginUser) authentication.getPrincipal();
+        recordLoginInfo(loginUser.getUserId());
+
+
+        SysUser sysUser = userService.selectUserByNickName(nickName);
+                //.selectUserByUserName(username);
+
         Long userId = sysUser.getUserId();
         // 鐢熸垚token
         String token = tokenService.createToken(loginUser);
@@ -156,6 +213,9 @@
     public void loginPreCheck(String username, String password)
     {
         // 鐢ㄦ埛鍚嶆垨瀵嗙爜涓虹┖ 閿欒
+        System.out.println(username);
+        System.out.println("099999999999999999999999999999999999");
+        System.out.println(password);
         if (StringUtils.isEmpty(username) || StringUtils.isEmpty(password))
         {
             AsyncManager.me().execute(AsyncFactory.recordLogininfor(username, Constants.LOGIN_FAIL, MessageUtils.message("not.null")));

--
Gitblit v1.9.1