blob: 538d4330d8d8dc9c417b46f34d7a4bf6b6db7f0f [file] [log] [blame]
wuchimedes079c1632025-04-02 22:01:20 +08001package com.example.g8backend.controller;
2
夜雨声烦e73ff922025-05-13 18:49:03 +08003import com.example.g8backend.dto.ApiResponse;
wuchimedes5280aa72025-04-03 20:49:34 +08004import com.example.g8backend.dto.UserRegisterDTO;
wuchimedes079c1632025-04-02 22:01:20 +08005import com.example.g8backend.entity.User;
wuchimedes22ee83c2025-04-25 00:17:47 +08006import com.example.g8backend.entity.UserStats;
wuchimedes079c1632025-04-02 22:01:20 +08007import com.example.g8backend.service.IUserService;
wuchimedes22ee83c2025-04-25 00:17:47 +08008import com.example.g8backend.service.IUserStatsService;
wuchimedes079c1632025-04-02 22:01:20 +08009import com.example.g8backend.util.JwtUtil;
wuchimedes5280aa72025-04-03 20:49:34 +080010import com.example.g8backend.util.mailUtil;
wuchimedes079c1632025-04-02 22:01:20 +080011import org.springframework.beans.factory.annotation.Autowired;
wuchimedes18addec2025-04-03 17:59:02 +080012import org.springframework.data.redis.core.RedisTemplate;
wuchimedes079c1632025-04-02 22:01:20 +080013import org.springframework.security.crypto.password.PasswordEncoder;
14import org.springframework.web.bind.annotation.*;
15
16import java.util.HashMap;
17import java.util.Map;
wuchimedes5280aa72025-04-03 20:49:34 +080018import java.util.UUID;
wuchimedes079c1632025-04-02 22:01:20 +080019
20@RestController
21@RequestMapping("/auth")
22public class AuthController {
23
24 @Autowired
25 private IUserService userService;
夜雨声烦e73ff922025-05-13 18:49:03 +080026
wuchimedes079c1632025-04-02 22:01:20 +080027 @Autowired
wuchimedes22ee83c2025-04-25 00:17:47 +080028 private IUserStatsService userStatsService;
夜雨声烦e73ff922025-05-13 18:49:03 +080029
wuchimedes22ee83c2025-04-25 00:17:47 +080030 @Autowired
wuchimedes5280aa72025-04-03 20:49:34 +080031 private mailUtil mailUtil;
夜雨声烦e73ff922025-05-13 18:49:03 +080032
wuchimedes5280aa72025-04-03 20:49:34 +080033 @Autowired
wuchimedes079c1632025-04-02 22:01:20 +080034 private PasswordEncoder passwordEncoder;
夜雨声烦e73ff922025-05-13 18:49:03 +080035
wuchimedes079c1632025-04-02 22:01:20 +080036 @Autowired
37 private JwtUtil jwtUtil;
夜雨声烦e73ff922025-05-13 18:49:03 +080038
wuchimedes18addec2025-04-03 17:59:02 +080039 @Autowired
夜雨声烦e73ff922025-05-13 18:49:03 +080040 private RedisTemplate<String, Object> redisTemplate;
wuchimedes18addec2025-04-03 17:59:02 +080041
wuchimedes5280aa72025-04-03 20:49:34 +080042 // 发送验证码
43 @PostMapping("/send_verification_code")
夜雨声烦e73ff922025-05-13 18:49:03 +080044 public ApiResponse<String> sendVerificationCode(@RequestBody UserRegisterDTO registerDTO) {
wuchimedes5280aa72025-04-03 20:49:34 +080045 if (userService.getUserByEmail(registerDTO.getEmail()) != null) {
夜雨声烦e73ff922025-05-13 18:49:03 +080046 return ApiResponse.error(400, "邮箱已存在");
wuchimedes5280aa72025-04-03 20:49:34 +080047 }
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);
夜雨声烦e73ff922025-05-13 18:49:03 +080053 return ApiResponse.success("验证码发送成功");
wuchimedes5280aa72025-04-03 20:49:34 +080054 }
55
wuchimedes079c1632025-04-02 22:01:20 +080056 // 用户注册
57 @PostMapping("/register")
夜雨声烦e73ff922025-05-13 18:49:03 +080058 public ApiResponse<String> register(@RequestBody UserRegisterDTO registerDTO) {
wuchimedes5280aa72025-04-03 20:49:34 +080059 if (userService.getUserByName(registerDTO.getUserName()) != null) {
夜雨声烦e73ff922025-05-13 18:49:03 +080060 return ApiResponse.error(400, "用户名已存在");
wuchimedes079c1632025-04-02 22:01:20 +080061 }
wuchimedes5280aa72025-04-03 20:49:34 +080062
63 if (!redisTemplate.hasKey(registerDTO.getInvitationCode())) {
夜雨声烦e73ff922025-05-13 18:49:03 +080064 return ApiResponse.error(400, "邀请码错误");
wuchimedes5280aa72025-04-03 20:49:34 +080065 }
夜雨声烦e73ff922025-05-13 18:49:03 +080066
67 Object cachedCode = redisTemplate.opsForValue().get(registerDTO.getEmail());
68 if (!registerDTO.getVerificationCode().equals(cachedCode)) {
69 return ApiResponse.error(400, "验证码错误");
wuchimedes5280aa72025-04-03 20:49:34 +080070 }
夜雨声烦e73ff922025-05-13 18:49:03 +080071
wuchimedes5280aa72025-04-03 20:49:34 +080072 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());
wuchimedesa0649c62025-04-05 15:53:39 +080078 user.setPasskey(UUID.randomUUID().toString().replace("-", ""));
wuchimedese5722e32025-04-13 17:38:50 +080079 userService.save(user);
wuchimedes5280aa72025-04-03 20:49:34 +080080
wuchimedes22ee83c2025-04-25 00:17:47 +080081 UserStats userStats = new UserStats();
82 userStats.setUserId(user.getUserId());
83 userStats.setPasskey(user.getPasskey());
84 userStatsService.save(userStats);
85
夜雨声烦e73ff922025-05-13 18:49:03 +080086 return ApiResponse.message("注册成功");
wuchimedes079c1632025-04-02 22:01:20 +080087 }
88
89 // 用户登录
90 @PostMapping("/login")
夜雨声烦e73ff922025-05-13 18:49:03 +080091 public ApiResponse<Map<String, String>> login(@RequestBody User user) {
wuchimedes079c1632025-04-02 22:01:20 +080092 User existingUser = userService.getUserByEmail(user.getEmail());
93 if (existingUser == null || !passwordEncoder.matches(user.getPassword(), existingUser.getPassword())) {
夜雨声烦e73ff922025-05-13 18:49:03 +080094 return ApiResponse.error(400, "用户名或密码错误");
wuchimedes079c1632025-04-02 22:01:20 +080095 }
夜雨声烦e73ff922025-05-13 18:49:03 +080096
wuchimedes223bfab2025-04-04 17:16:05 +080097 String token = jwtUtil.generateToken(existingUser.getUserId());
wuchimedes079c1632025-04-02 22:01:20 +080098 Map<String, String> response = new HashMap<>();
99 response.put("token", token);
夜雨声烦e73ff922025-05-13 18:49:03 +0800100
101 return ApiResponse.success(response);
wuchimedes079c1632025-04-02 22:01:20 +0800102 }
wuchimedes18addec2025-04-03 17:59:02 +0800103
夜雨声烦e73ff922025-05-13 18:49:03 +0800104 // 测试 Redis
wuchimedes18addec2025-04-03 17:59:02 +0800105 @GetMapping("/test_redis")
夜雨声烦e73ff922025-05-13 18:49:03 +0800106 public ApiResponse<String> testRedis() {
107 Object value = redisTemplate.opsForValue().get("test");
108 return ApiResponse.success("test redis ok");
wuchimedes18addec2025-04-03 17:59:02 +0800109 }
夜雨声烦e73ff922025-05-13 18:49:03 +0800110}