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; |
22301071 | 3e8aabf | 2025-05-24 21:38:17 +0800 | [diff] [blame] | 13 | import org.springframework.security.core.context.SecurityContextHolder; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 14 | import org.springframework.security.crypto.password.PasswordEncoder; |
| 15 | import org.springframework.web.bind.annotation.*; |
22301071 | 3e8aabf | 2025-05-24 21:38:17 +0800 | [diff] [blame] | 16 | import jakarta.servlet.http.HttpServletRequest; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 17 | import java.util.HashMap; |
| 18 | import java.util.Map; |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 19 | import java.util.UUID; |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 20 | |
| 21 | @RestController |
| 22 | @RequestMapping("/auth") |
| 23 | public class AuthController { |
| 24 | |
| 25 | @Autowired |
| 26 | private IUserService userService; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 27 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 28 | @Autowired |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 29 | private IUserStatsService userStatsService; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 30 | |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 31 | @Autowired |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 32 | private mailUtil mailUtil; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 33 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 34 | @Autowired |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 35 | private PasswordEncoder passwordEncoder; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 36 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 37 | @Autowired |
| 38 | private JwtUtil jwtUtil; |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 39 | |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 40 | @Autowired |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 41 | private RedisTemplate<String, Object> redisTemplate; |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 42 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 43 | // 发送验证码 |
| 44 | @PostMapping("/send_verification_code") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 45 | public ApiResponse<String> sendVerificationCode(@RequestBody UserRegisterDTO registerDTO) { |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 46 | if (userService.getUserByEmail(registerDTO.getEmail()) != null) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 47 | return ApiResponse.error(400, "邮箱已存在"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | String verificationCode = UUID.randomUUID().toString().substring(0, 6); |
| 51 | mailUtil.sendMail(registerDTO.getEmail(), "PT平台注册验证码", "您的验证码为:" + verificationCode + ",验证码十分钟内有效,请勿泄露。"); |
| 52 | |
| 53 | redisTemplate.opsForValue().set(registerDTO.getEmail(), verificationCode, 10 * 60, java.util.concurrent.TimeUnit.SECONDS); |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 54 | return ApiResponse.success("验证码发送成功"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 55 | } |
| 56 | |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 57 | // 用户注册 |
| 58 | @PostMapping("/register") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 59 | public ApiResponse<String> register(@RequestBody UserRegisterDTO registerDTO) { |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 60 | if (userService.getUserByName(registerDTO.getUserName()) != null) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 61 | return ApiResponse.error(400, "用户名已存在"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 62 | } |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 63 | |
| 64 | if (!redisTemplate.hasKey(registerDTO.getInvitationCode())) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 65 | return ApiResponse.error(400, "邀请码错误"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 66 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 67 | |
| 68 | Object cachedCode = redisTemplate.opsForValue().get(registerDTO.getEmail()); |
| 69 | if (!registerDTO.getVerificationCode().equals(cachedCode)) { |
| 70 | return ApiResponse.error(400, "验证码错误"); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 71 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 72 | |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 73 | redisTemplate.delete(registerDTO.getEmail()); |
| 74 | |
| 75 | User user = new User(); |
| 76 | user.setUserName(registerDTO.getUserName()); |
| 77 | user.setPassword(passwordEncoder.encode(registerDTO.getPassword())); |
| 78 | user.setEmail(registerDTO.getEmail()); |
wuchimedes | a0649c6 | 2025-04-05 15:53:39 +0800 | [diff] [blame] | 79 | user.setPasskey(UUID.randomUUID().toString().replace("-", "")); |
wuchimedes | e5722e3 | 2025-04-13 17:38:50 +0800 | [diff] [blame] | 80 | userService.save(user); |
wuchimedes | 5280aa7 | 2025-04-03 20:49:34 +0800 | [diff] [blame] | 81 | |
wuchimedes | 22ee83c | 2025-04-25 00:17:47 +0800 | [diff] [blame] | 82 | UserStats userStats = new UserStats(); |
| 83 | userStats.setUserId(user.getUserId()); |
| 84 | userStats.setPasskey(user.getPasskey()); |
| 85 | userStatsService.save(userStats); |
| 86 | |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 87 | return ApiResponse.message("注册成功"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | // 用户登录 |
| 91 | @PostMapping("/login") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 92 | public ApiResponse<Map<String, String>> login(@RequestBody User user) { |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 93 | User existingUser = userService.getUserByEmail(user.getEmail()); |
| 94 | if (existingUser == null || !passwordEncoder.matches(user.getPassword(), existingUser.getPassword())) { |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 95 | return ApiResponse.error(400, "用户名或密码错误"); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 96 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 97 | |
夜雨声烦 | 7affa47 | 2025-05-20 19:27:16 +0800 | [diff] [blame] | 98 | if (existingUser.getIsBanned()) { |
| 99 | return ApiResponse.error(403, "账号已被封禁,请联系管理员"); |
| 100 | } |
| 101 | |
wuchimedes | 223bfab | 2025-04-04 17:16:05 +0800 | [diff] [blame] | 102 | String token = jwtUtil.generateToken(existingUser.getUserId()); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 103 | Map<String, String> response = new HashMap<>(); |
| 104 | response.put("token", token); |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 105 | |
| 106 | return ApiResponse.success(response); |
wuchimedes | 079c163 | 2025-04-02 22:01:20 +0800 | [diff] [blame] | 107 | } |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 108 | |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 109 | // 测试 Redis |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 110 | @GetMapping("/test_redis") |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 111 | public ApiResponse<String> testRedis() { |
| 112 | Object value = redisTemplate.opsForValue().get("test"); |
| 113 | return ApiResponse.success("test redis ok"); |
wuchimedes | 18addec | 2025-04-03 17:59:02 +0800 | [diff] [blame] | 114 | } |
22301071 | 3e8aabf | 2025-05-24 21:38:17 +0800 | [diff] [blame] | 115 | |
| 116 | //刷新token |
| 117 | @PostMapping("/refresh-token") |
| 118 | public ApiResponse<String> refreshToken(HttpServletRequest request) { |
| 119 | Object principal = SecurityContextHolder.getContext().getAuthentication().getPrincipal(); |
| 120 | if (!(principal instanceof Long userId)) { |
| 121 | return ApiResponse.error(401, "未认证,无法刷新token"); |
| 122 | } |
| 123 | String oldToken = request.getHeader("Authorization"); |
| 124 | if (oldToken != null && oldToken.startsWith("Bearer ")) { |
| 125 | oldToken = oldToken.substring(7); |
| 126 | } |
| 127 | String newToken = jwtUtil.generateToken(userId); |
| 128 | return ApiResponse.success("Token刷新成功", newToken); |
| 129 | } |
夜雨声烦 | e73ff92 | 2025-05-13 18:49:03 +0800 | [diff] [blame] | 130 | } |
22301071 | a1c4832 | 2025-05-24 22:00:28 +0800 | [diff] [blame] | 131 | |