blob: 2f36500e04245560f55b2a24c6a1fb06b58a9768 [file] [log] [blame]
wuchimedes079c1632025-04-02 22:01:20 +08001package com.example.g8backend.controller;
2
wuchimedes5280aa72025-04-03 20:49:34 +08003import com.example.g8backend.dto.UserRegisterDTO;
wuchimedes079c1632025-04-02 22:01:20 +08004import com.example.g8backend.entity.User;
5import com.example.g8backend.service.IUserService;
6import com.example.g8backend.util.JwtUtil;
wuchimedes5280aa72025-04-03 20:49:34 +08007import com.example.g8backend.util.mailUtil;
wuchimedes079c1632025-04-02 22:01:20 +08008import org.springframework.beans.factory.annotation.Autowired;
wuchimedes18addec2025-04-03 17:59:02 +08009import org.springframework.data.redis.core.RedisTemplate;
wuchimedes079c1632025-04-02 22:01:20 +080010import org.springframework.http.ResponseEntity;
11import org.springframework.security.crypto.password.PasswordEncoder;
12import org.springframework.web.bind.annotation.*;
13
14import java.util.HashMap;
15import java.util.Map;
wuchimedes5280aa72025-04-03 20:49:34 +080016import java.util.UUID;
wuchimedes079c1632025-04-02 22:01:20 +080017
18@RestController
19@RequestMapping("/auth")
20public class AuthController {
21
22 @Autowired
23 private IUserService userService;
wuchimedes079c1632025-04-02 22:01:20 +080024 @Autowired
wuchimedes5280aa72025-04-03 20:49:34 +080025 private mailUtil mailUtil;
wuchimedes5280aa72025-04-03 20:49:34 +080026 @Autowired
wuchimedes079c1632025-04-02 22:01:20 +080027 private PasswordEncoder passwordEncoder;
wuchimedes079c1632025-04-02 22:01:20 +080028 @Autowired
29 private JwtUtil jwtUtil;
wuchimedes18addec2025-04-03 17:59:02 +080030 @Autowired
31 RedisTemplate<String, Object> redisTemplate;
32
wuchimedes5280aa72025-04-03 20:49:34 +080033 // 发送验证码
34 @PostMapping("/send_verification_code")
35 public ResponseEntity<?> sendVerificationCode(@RequestBody UserRegisterDTO registerDTO) {
36 if (userService.getUserByEmail(registerDTO.getEmail()) != null) {
37 return ResponseEntity.badRequest().body("邮箱已存在");
38 }
39
40 String verificationCode = UUID.randomUUID().toString().substring(0, 6);
41 mailUtil.sendMail(registerDTO.getEmail(), "PT平台注册验证码", "您的验证码为:" + verificationCode + ",验证码十分钟内有效,请勿泄露。");
42
43 redisTemplate.opsForValue().set(registerDTO.getEmail(), verificationCode, 10 * 60, java.util.concurrent.TimeUnit.SECONDS);
44 return ResponseEntity.ok("验证码发送成功");
45 }
46
wuchimedes079c1632025-04-02 22:01:20 +080047 // 用户注册
48 @PostMapping("/register")
wuchimedes5280aa72025-04-03 20:49:34 +080049 public ResponseEntity<?> register(@RequestBody UserRegisterDTO registerDTO) {
50 if (userService.getUserByName(registerDTO.getUserName()) != null) {
wuchimedes079c1632025-04-02 22:01:20 +080051 return ResponseEntity.badRequest().body("用户名已存在");
52 }
wuchimedes5280aa72025-04-03 20:49:34 +080053
54 if (!redisTemplate.hasKey(registerDTO.getInvitationCode())) {
55 return ResponseEntity.badRequest().body("邀请码错误");
56 }
57 if (!registerDTO.getVerificationCode().equals(redisTemplate.opsForValue().get(registerDTO.getEmail()))) {
58 return ResponseEntity.badRequest().body("验证码错误");
59 }
60 redisTemplate.delete(registerDTO.getEmail());
61
62 User user = new User();
63 user.setUserName(registerDTO.getUserName());
64 user.setPassword(passwordEncoder.encode(registerDTO.getPassword()));
65 user.setEmail(registerDTO.getEmail());
wuchimedesa0649c62025-04-05 15:53:39 +080066
67 // passkey 用于在客户端发送announce请求时获取用户信息
68 user.setPasskey(UUID.randomUUID().toString().replace("-", ""));
wuchimedes079c1632025-04-02 22:01:20 +080069 userService.registerUser(user);
wuchimedes5280aa72025-04-03 20:49:34 +080070
wuchimedes079c1632025-04-02 22:01:20 +080071 return ResponseEntity.ok("注册成功");
72 }
73
74 // 用户登录
75 @PostMapping("/login")
76 public ResponseEntity<?> login(@RequestBody User user) {
77 User existingUser = userService.getUserByEmail(user.getEmail());
78 if (existingUser == null || !passwordEncoder.matches(user.getPassword(), existingUser.getPassword())) {
79 return ResponseEntity.badRequest().body("用户名或密码错误");
80 }
wuchimedes223bfab2025-04-04 17:16:05 +080081 String token = jwtUtil.generateToken(existingUser.getUserId());
wuchimedes079c1632025-04-02 22:01:20 +080082 Map<String, String> response = new HashMap<>();
83 response.put("token", token);
84 return ResponseEntity.ok(response);
85 }
wuchimedes18addec2025-04-03 17:59:02 +080086
87 @GetMapping("/test_redis")
88 public ResponseEntity<?> testRedis() {
89 redisTemplate.opsForValue().get("test");
90 return ResponseEntity.ok("test redis ok");
91 }
wuchimedes079c1632025-04-02 22:01:20 +080092}