wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 1 | package com.example.g8backend.controller; |
| 2 | |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 3 | import com.example.g8backend.dto.ApiResponse; |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 4 | import com.example.g8backend.dto.UserRegisterDTO; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 5 | import com.example.g8backend.entity.User; |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 6 | import com.example.g8backend.entity.UserStats; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 7 | import com.example.g8backend.service.IUserService; |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 8 | import com.example.g8backend.service.IUserStatsService; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 9 | import com.example.g8backend.util.JwtUtil; |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 10 | import com.example.g8backend.util.mailUtil; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 11 | import org.springframework.beans.factory.annotation.Autowired; |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 12 | import org.springframework.data.redis.core.RedisTemplate; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 13 | import org.springframework.security.crypto.password.PasswordEncoder; |
| 14 | import org.springframework.web.bind.annotation.*; |
| 15 | |
| 16 | import java.util.HashMap; |
| 17 | import java.util.Map; |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 18 | import java.util.UUID; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 19 | |
| 20 | @RestController |
| 21 | @RequestMapping("/auth") |
| 22 | public class AuthController { |
| 23 | |
| 24 | @Autowired |
| 25 | private IUserService userService; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 26 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 27 | @Autowired |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 28 | private IUserStatsService userStatsService; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 29 | |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 30 | @Autowired |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 31 | private mailUtil mailUtil; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 32 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 33 | @Autowired |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 34 | private PasswordEncoder passwordEncoder; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 35 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 36 | @Autowired |
| 37 | private JwtUtil jwtUtil; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 38 | |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 39 | @Autowired |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 40 | private RedisTemplate<String, Object> redisTemplate; |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 41 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 42 | // 发送验证码 |
| 43 | @PostMapping("/send_verification_code") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 44 | public ApiResponse<String> sendVerificationCode(@RequestBody UserRegisterDTO registerDTO) { |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 45 | if (userService.getUserByEmail(registerDTO.getEmail()) != null) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 46 | return ApiResponse.error(400, "邮箱已存在"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 47 | } |
| 48 | |
| 49 | String verificationCode = UUID.randomUUID().toString().substring(0, 6); |
| 50 | mailUtil.sendMail(registerDTO.getEmail(), "PT平台注册验证码", "您的验证码为:" + verificationCode + ",验证码十分钟内有效,请勿泄露。"); |
| 51 | |
| 52 | redisTemplate.opsForValue().set(registerDTO.getEmail(), verificationCode, 10 * 60, java.util.concurrent.TimeUnit.SECONDS); |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 53 | return ApiResponse.success("验证码发送成功"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 54 | } |
| 55 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 56 | // 用户注册 |
| 57 | @PostMapping("/register") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 58 | public ApiResponse<String> register(@RequestBody UserRegisterDTO registerDTO) { |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 59 | if (userService.getUserByName(registerDTO.getUserName()) != null) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 60 | return ApiResponse.error(400, "用户名已存在"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 61 | } |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 62 | |
| 63 | if (!redisTemplate.hasKey(registerDTO.getInvitationCode())) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 64 | return ApiResponse.error(400, "邀请码错误"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 65 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 66 | |
| 67 | Object cachedCode = redisTemplate.opsForValue().get(registerDTO.getEmail()); |
| 68 | if (!registerDTO.getVerificationCode().equals(cachedCode)) { |
| 69 | return ApiResponse.error(400, "验证码错误"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 70 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 71 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 72 | redisTemplate.delete(registerDTO.getEmail()); |
| 73 | |
| 74 | User user = new User(); |
| 75 | user.setUserName(registerDTO.getUserName()); |
| 76 | user.setPassword(passwordEncoder.encode(registerDTO.getPassword())); |
| 77 | user.setEmail(registerDTO.getEmail()); |
wuchimedes | a0649c6 | 2025-04-05 15:53:39 +0800 | [diff] [blame] | 78 | user.setPasskey(UUID.randomUUID().toString().replace("-", "")); |
wuchimedes | e5722e3 | 2025-04-13 17:38:50 +0800 | [diff] [blame] | 79 | userService.save(user); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 80 | |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 81 | UserStats userStats = new UserStats(); |
| 82 | userStats.setUserId(user.getUserId()); |
| 83 | userStats.setPasskey(user.getPasskey()); |
| 84 | userStatsService.save(userStats); |
| 85 | |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 86 | return ApiResponse.message("注册成功"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 87 | } |
| 88 | |
| 89 | // 用户登录 |
| 90 | @PostMapping("/login") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 91 | public ApiResponse<Map<String, String>> login(@RequestBody User user) { |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 92 | User existingUser = userService.getUserByEmail(user.getEmail()); |
| 93 | if (existingUser == null || !passwordEncoder.matches(user.getPassword(), existingUser.getPassword())) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 94 | return ApiResponse.error(400, "用户名或密码错误"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 95 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 96 | |
wuchimedes | 223bfab | 2025-04-04 17:16:05 +0800 | [diff] [blame] | 97 | String token = jwtUtil.generateToken(existingUser.getUserId()); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 98 | Map<String, String> response = new HashMap<>(); |
| 99 | response.put("token", token); |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 100 | |
| 101 | return ApiResponse.success(response); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 102 | } |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 103 | |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 104 | // 测试 Redis |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 105 | @GetMapping("/test_redis") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 106 | public ApiResponse<String> testRedis() { |
| 107 | Object value = redisTemplate.opsForValue().get("test"); |
| 108 | return ApiResponse.success("test redis ok"); |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 109 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 110 | } |