From 3e02abec44a648f01174a4c3494a96ccb46a3b1a Mon Sep 17 00:00:00 2001
From: zqy <2522236926@qq.com>
Date: 星期二, 11 十一月 2025 21:39:20 +0800
Subject: [PATCH] 会员&充值相关模块
---
ruoyi-admin/src/main/java/com/ruoyi/web/controller/system/SysLoginController.java | 134 +++++++++++++++++++++++++++++++++++++++++---
1 files changed, 124 insertions(+), 10 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 45e5a2b..9cd5b76 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
@@ -1,14 +1,20 @@
package com.ruoyi.web.controller.system;
-import java.util.List;
-import java.util.Set;
+import java.time.Instant;
+import java.time.LocalDateTime;
+import java.time.ZoneId;
+import java.time.temporal.ChronoUnit;
+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.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestBody;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.http.ResponseEntity;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.web.bind.annotation.*;
import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.entity.SysMenu;
@@ -36,6 +42,15 @@
@Autowired
private SysPermissionService permissionService;
+ @Autowired
+ private ISysUserService userService;
+
+ @Autowired
+ private EmailService emailService;
+
+ @Autowired
+ private VerificationCodeService codeService;
+
/**
* 鐧诲綍鏂规硶
*
@@ -45,13 +60,67 @@
@PostMapping("/login")
public AjaxResult login(@RequestBody LoginBody loginBody)
{
- AjaxResult ajax = AjaxResult.success();
// 鐢熸垚浠ょ墝
- String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
+ System.out.println(loginBody);
+ String token = loginService.login(loginBody.getNickname(), loginBody.getPassword(), loginBody.getCode(),
loginBody.getUuid());
- ajax.put(Constants.TOKEN, token);
- return ajax;
+
+ HashMap<String, String> tokenMap = new HashMap<>();
+ tokenMap.put("token",token);
+ // tokenMap.put("roid",roid)
+ return AjaxResult.success(tokenMap);
}
+
+ /**
+ * 鐧诲綍鏂规硶锛堜笉闇�瑕侀獙璇佺爜锛�
+ *
+ * @param loginBody 鐧诲綍淇℃伅
+ * @return 缁撴灉
+ */
+ @PostMapping("/login/no")
+ public AjaxResult login2(@RequestBody LoginBody loginBody)
+ {
+ // 鐢熸垚浠ょ墝
+ String token = loginService.loginWithoutValidate(loginBody.getUsername(), loginBody.getPassword());
+ HashMap<String, String> tokenMap = new HashMap<>();
+ tokenMap.put("token",token);
+ return AjaxResult.success(tokenMap);
+ }
+
+ /**
+ * 鑾峰彇鐢ㄦ埛褰撳墠鍓╀綑鐨勮瘯鐢ㄥぉ鏁�
+ */
+
+ @GetMapping("/leave")
+ public AjaxResult getUserLeave(){
+ Long userId = SecurityUtils.getUserId();
+ SysUser sysUser = userService.selectUserById(userId);
+ 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());
+
+ return AjaxResult.success(daysPassed > sysUser.getRemainTime() ? "鎮ㄧ殑璇曠敤鏈熷凡缁忕粨鏉燂紝璇蜂粯璐圭户缁娇鐢�":"鎮ㄨ繕鏈� " + (sysUser.getRemainTime() - daysPassed) + " 澶╃殑璇曠敤澶╂暟");
+ }else return AjaxResult.success("灏婃暚鐨勪細鍛樼敤鎴凤紝鎮ㄥソ锛�");
+
+ }
+
+ /**
+ * 绠$悊鍛樻巿浜堜細鍛�
+ */
+ @GetMapping("/member/{userId}")
+ public AjaxResult setMember(@PathVariable("userId") Long userId){
+ SysUser sysUser = userService.selectUserById(userId);
+ sysUser.setStatus("0");
+ sysUser.setPaid(1);
+ System.out.println("[{{{{{"+sysUser);
+ userService.updateUser(sysUser);
+
+ return AjaxResult.success(sysUser.getUserName() + " 鐢ㄦ埛宸叉垚涓轰細鍛�");
+ }
+
/**
* 鑾峰彇鐢ㄦ埛淇℃伅
@@ -62,10 +131,13 @@
public AjaxResult getInfo()
{
SysUser user = SecurityUtils.getLoginUser().getUser();
+ // System.out.println(user);
+// System.out.println("===========0oiii999999999999999-000000000000000000");
// 瑙掕壊闆嗗悎
Set<String> roles = permissionService.getRolePermission(user);
// 鏉冮檺闆嗗悎
Set<String> permissions = permissionService.getMenuPermission(user);
+ System.out.println(permissions);
AjaxResult ajax = AjaxResult.success();
ajax.put("user", user);
ajax.put("roles", roles);
@@ -82,7 +154,49 @@
public AjaxResult getRouters()
{
Long userId = SecurityUtils.getUserId();
+ System.out.println("9222222222kkkkkkkkkkksssssssssssssssssss");
List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);//杩欓噷涔嬪悗宸茬粡鐢熸垚浜嗘爲褰㈢粨鏋�
+ 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