From 4502f650f4816e55b5c7bf751ffce3aa0dce72dd Mon Sep 17 00:00:00 2001
From: zqy <2522236926@qq.com>
Date: 星期二, 14 十月 2025 18:13:07 +0800
Subject: [PATCH] 找回密码功能

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java |   49 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 49 insertions(+), 0 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
index 8d8fa3c..9994f0a 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
@@ -9,7 +9,10 @@
 import com.ruoyi.common.annotation.Anonymous;
 import com.ruoyi.framework.web.domain.server.Sys;
 import com.ruoyi.system.service.ISysUserService;
+import com.ruoyi.system.service.impl.EmailService;
+import com.ruoyi.system.service.impl.VerificationCodeService;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
 import com.ruoyi.common.constant.Constants;
@@ -41,6 +44,12 @@
 
     @Autowired
     private ISysUserService userService;
+
+    @Autowired
+    private EmailService emailService;
+
+    @Autowired
+    private VerificationCodeService codeService;
 
     /**
      * 鐧诲綍鏂规硶
@@ -150,4 +159,44 @@
         System.out.println(menus);
         return AjaxResult.success(menuService.buildMenus(menus));//杩欓噷涔嬪悗灏卞皝瑁呭ソ浜嗗彂缁欏墠绔殑vo
     }
+
+    // 姝ラ1锛氳姹傚彂閫侀獙璇佺爜
+    @PostMapping("/getCode")
+    public AjaxResult requestPasswordReset(@RequestBody SysUser sysUser) {
+        // 楠岃瘉璐﹀彿鍜岄偖绠辨槸鍚﹀尮閰�
+        SysUser user = userService.checkEmail(sysUser.getNickName(),sysUser.getEmail());
+        if (user == null) {
+            return AjaxResult.error("璐﹀彿鎴栭偖绠变笉鍖归厤");
+        }
+
+        // 鐢熸垚骞跺彂閫侀獙璇佺爜
+        String verificationCode = codeService.generateCode();
+        codeService.saveCode(sysUser.getNickName(), verificationCode);
+        emailService.sendVerificationCode(sysUser.getEmail(), verificationCode);
+
+        return AjaxResult.success("楠岃瘉鐮佸凡鍙戦�佽嚦鎮ㄧ殑閭");
+    }
+
+    // 姝ラ2锛氶獙璇侀獙璇佺爜骞堕噸缃瘑鐮�
+    @PostMapping("/reset")
+    public AjaxResult resetPassword(@RequestParam String nickName,
+                                           @RequestParam String verificationCode,
+                                           @RequestParam String newPassword) {
+        // 楠岃瘉楠岃瘉鐮�
+        if (!codeService.validateCode(nickName, verificationCode)) {
+            return AjaxResult.error("楠岃瘉鐮佹棤鏁堟垨宸茶繃鏈�");
+        }
+
+        // 鏇存柊瀵嗙爜
+        SysUser user = userService.selectUserByNickName(nickName);
+        System.out.println(user);
+        if (user != null) {
+            newPassword = SecurityUtils.encryptPassword(newPassword);
+            user.setPassword(newPassword);
+            userService.updateUser(user);// 瀹為檯搴旂敤涓簲瀵瑰瘑鐮佸姞瀵�
+            return AjaxResult.success("瀵嗙爜閲嶇疆鎴愬姛");
+        }
+        return AjaxResult.error("鐢ㄦ埛涓嶅瓨鍦�");
+    }
+
 }

--
Gitblit v1.9.1