zqy
2025-11-11 3e02abec44a648f01174a4c3494a96ccb46a3b1a
ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java
@@ -4,15 +4,15 @@
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.temporal.ChronoUnit;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Set;
import java.util.*;
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;
@@ -44,6 +44,12 @@
    @Autowired
    private ISysUserService userService;
    @Autowired
    private EmailService emailService;
    @Autowired
    private VerificationCodeService codeService;
    /**
     * 登录方法
@@ -89,14 +95,16 @@
    public AjaxResult getUserLeave(){
        Long userId = SecurityUtils.getUserId();
        SysUser sysUser = userService.selectUserById(userId);
        Date startTime = sysUser.getCreateTime();
        if(sysUser.getPaid()!=null&&sysUser.getPaid()==0) {
            Date startTime = sysUser.getCreateTime();
            // 安全转换
            Instant instant = startTime.toInstant();
            LocalDateTime startDateTime = instant.atZone(ZoneId.systemDefault()).toLocalDateTime();
            long daysPassed = ChronoUnit.DAYS.between(startDateTime, LocalDateTime.now());
        // 安全转换
        Instant instant = startTime.toInstant();
        LocalDateTime startDateTime = instant.atZone(ZoneId.systemDefault()).toLocalDateTime();
        long daysPassed = ChronoUnit.DAYS.between(startDateTime, LocalDateTime.now());
            return AjaxResult.success(daysPassed > sysUser.getRemainTime() ? "您的试用期已经结束,请付费继续使用":"您还有 " + (sysUser.getRemainTime() - daysPassed) + " 天的试用天数");
        }else return AjaxResult.success("尊敬的会员用户,您好!");
        return AjaxResult.success("试用提醒:您还有 "+ (7L - daysPassed) + " 天的试用天数");
    }
    /**
@@ -151,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("用户不存在");
    }
}