增加付费片单,修复种子列表搜索排序,修复token无效问题

Change-Id: I45874a400994e837d7b2590611b84b661749c24b
diff --git a/src/main/java/com/example/myproject/service/UserService.java b/src/main/java/com/example/myproject/service/UserService.java
index ca16ddf..9967591 100644
--- a/src/main/java/com/example/myproject/service/UserService.java
+++ b/src/main/java/com/example/myproject/service/UserService.java
@@ -1,334 +1,5 @@
-//package com.example.myproject.service;
-//import cn.dev33.satoken.stp.StpUtil;
-//import com.example.myproject.entity.FriendRelation;
-//import com.example.myproject.entity.User;
-//import com.example.myproject.entity.Users;
-//import com.example.myproject.entity.UserInviteCode;
-//import com.example.myproject.repository.FriendRelationRepository;
-//import com.example.myproject.repository.UserRepository;
-//import com.example.myproject.repository.UserInviteCodeRepository;
-//import org.springframework.beans.factory.annotation.Autowired;
-//import org.springframework.stereotype.Service;
-//import org.springframework.web.multipart.MultipartFile;
-//
-//import javax.servlet.http.HttpServletRequest;
-//import java.io.File;
-//import java.io.IOException;
-//import java.nio.file.Files;
-//import java.nio.file.Path;
-//import java.nio.file.Paths;
-//import java.time.LocalDateTime;
-//import java.util.*;
-//
-//@Service
-//public class UserService {
-//
-//    @Autowired
-//    private UserRepository userRepository;
-//
-//    @Autowired
-//    private UserInviteCodeRepository userInviteCodeRepository;
-//
-//    @Autowired
-//    private FriendRelationRepository friendRelationRepository;
-//
-//    // 生成邀请码
-//    public Map<String, Object> generateInviteCode(Long userId) {
-//        // 获取用户信息
-//        Users user = userRepository.findById(userId).orElse(null);
-//
-//        // 如果用户不存在,返回错误
-//        if (user == null) {
-//            Map<String, Object> errorResponse = new HashMap<>();
-//            errorResponse.put("status", "failure");
-//            errorResponse.put("message", "用户不存在");
-//            return errorResponse;
-//        }
-//
-//        // 检查用户的邀请数量
-//        if (user.getInviteCount() <= 0) {
-//            Map<String, Object> errorResponse = new HashMap<>();
-//            errorResponse.put("status", "failure");
-//            errorResponse.put("message", "没有剩余的邀请码");
-//            return errorResponse;
-//        }
-//
-//        // 生成唯一的邀请码
-//        String inviteCode = generateUniqueInviteCode();
-//
-//        // 将邀请码保存到 `user_invite_code` 表
-//        UserInviteCode userInviteCode = new UserInviteCode();
-//        userInviteCode.setUserId(userId);
-//        userInviteCode.setInviteCode(inviteCode);
-//        userInviteCode.setCreatedAt(java.time.LocalDateTime.now());
-//
-//        userInviteCodeRepository.save(userInviteCode);
-//
-//        // 更新用户的 `invite_count`,减少1
-//        user.setInviteCount(user.getInviteCount() - 1);
-//        userRepository.save(user);
-//
-//        // 返回成功信息
-//        Map<String, Object> response = new HashMap<>();
-//        response.put("status", "success");
-//        response.put("message", "邀请码生成成功");
-//        response.put("invite_code", inviteCode);
-//
-//        return response;
-//    }
-//
-//    // 生成唯一的邀请码,使用26个字母(大小写)
-//    private String generateUniqueInviteCode() {
-//        String characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
-//        StringBuilder inviteCode = new StringBuilder();
-//
-//        Random random = new Random();
-//        for (int i = 0; i < 10; i++) {
-//            inviteCode.append(characters.charAt(random.nextInt(characters.length())));
-//        }
-//
-//        return inviteCode.toString();
-//    }
-//
-//    public String registerUser(String username, String email, String password, String role, String inviteCode) {
-//        // 检查邮箱是否已经注册
-//        Optional<Users> existingEmailUser = userRepository.findByEmail(email);
-//        if (existingEmailUser.isPresent()) {
-//            return "该邮箱已被注册";
-//        }
-//
-//        // 检查用户名是否已经存在
-//        Optional<Users> existingUsernameUser = userRepository.findByUsername(username); // 需要根据用户名查询
-//        if (existingUsernameUser.isPresent()) {
-//            return "该用户名已被注册";
-//        }
-//
-//        // 检查邀请码是否有效
-//        if (inviteCode == null || inviteCode.isEmpty()) {
-//            return "邀请码不能为空";
-//        }
-//
-//        Optional<UserInviteCode> invite = userInviteCodeRepository.findByInviteCode(inviteCode);
-//        if (invite.isEmpty() || invite.get().getIsUsed()) {
-//            return "邀请码无效或已被使用";
-//        }
-//
-//        // 设置默认等级为2(由于邀请码有效)
-//        Long level = 2L;
-//
-//        // 设置默认头像 URL
-//        String avatarUrl = "https://example.com/default-avatar.jpg";  // 默认头像
-//
-//        // 获取邀请码对应的用户ID
-//        UserInviteCode inviteEntity = invite.get();
-//        Long inviteUserId = inviteEntity.getUserId();
-//
-//        // 创建新用户
-//        Users newUser = new Users();
-//        newUser.setUsername(username);
-//        newUser.setEmail(email);
-//        newUser.setPassword(password);
-//        newUser.setRole(role);
-//        newUser.setInviteCount(0);  // 初始邀请码数量为 0
-//        newUser.setLevel(level);
-//        newUser.setAvatarUrl(avatarUrl);  // 设置默认头像
-//        newUser.setRegistrationDate(new java.util.Date());  // 设置注册日期
-//        newUser.setCurrentExperience(0);  // 默认经验为 0
-//        newUser.setCurrentSeedingHours(0f);  // 默认做种时长为 0
-//        newUser.setRegistrationTime(new java.util.Date());  // 设置注册时间为当前时间
-//
-//        // 保存用户信息
-//        userRepository.save(newUser);
-//
-//        FriendRelation newFriendRelation  = new FriendRelation();
-//        newFriendRelation.setUserId(newUser.getUserId());
-//        newFriendRelation.setCreateTime(new Date());
-//        newFriendRelation.setFriendId(inviteUserId);
-//
-//        FriendRelation newFriendRelations  = new FriendRelation();
-//        newFriendRelations.setUserId(inviteUserId);
-//        newFriendRelations.setCreateTime(new Date());
-//        newFriendRelations.setFriendId(newUser.getUserId());
-//        friendRelationRepository.save(newFriendRelation);
-//        friendRelationRepository.save(newFriendRelations);
-//        // 更新邀请码的使用状态
-//        inviteEntity.setIsUsed(true);
-//        userInviteCodeRepository.save(inviteEntity);
-//
-//        return "用户注册成功";
-//    }
-//
-//
-//    public String loginUser(String username, String password) {
-//        // 检查用户是否存在
-//        Optional<Users> userOptional = userRepository.findByUsername(username);
-//        if (userOptional.isEmpty()) {
-//            return "用户名不存在";
-//        }
-//
-//        Users user = userOptional.get();
-//
-//        // 检查密码是否正确
-//        if (!user.getPassword().equals(password)) {
-//            return "密码错误";
-//        }
-//        StpUtil.login(user.getUserId());
-//
-//        // 登录成功
-//        return "登录成功";
-//    }
-//
-//    public String changePassword(Long userId, String oldPassword, String newPassword, String confirmPassword) {
-//        // 查找用户
-//        Users user = userRepository.findById(userId).orElse(null);
-//
-//        if (user == null) {
-//            return "用户不存在";
-//        }
-//
-//        // 检查旧密码是否正确
-//        if (!user.getPassword().equals(oldPassword)) {
-//            return "旧密码错误";
-//        }
-//
-//        // 检查新密码和确认密码是否一致
-//        if (!newPassword.equals(confirmPassword)) {
-//            return "新密码与确认密码不一致";
-//        }
-//
-//        // 更新密码
-//        user.setPassword(newPassword);
-//        userRepository.save(user);
-//
-//        return "密码修改成功";
-//    }
-//
-//    // 获取用户个人资料
-//    public Map<String, Object> getProfile(Long userId) {
-//        Optional<Users> userOptional = userRepository.findById(userId);
-//
-//        // 如果用户不存在,返回null或者可以抛出异常
-//        if (userOptional.isEmpty()) {
-//            return null; // 可以返回 null 或者根据需要返回错误信息
-//        }
-//
-//        Users user = userOptional.get();
-//
-//        // 将需要的字段放入 Map 中
-//        Map<String, Object> profile = new LinkedHashMap<>();
-//        profile.put("avatarUrl", user.getAvatarUrl());
-//        profile.put("username", user.getUsername());
-//        profile.put("email", user.getEmail());
-//        profile.put("gender", user.getGender());
-//        profile.put("description", user.getDescription());
-//        profile.put("hobbies", user.getHobbies());
-//        profile.put("level", user.getLevel());
-//        profile.put("Experience", user.getCurrentExperience());
-//        profile.put("uploadCount", user.getUploadCount());
-//        profile.put("downloadCount", user.getDownloadCount());
-//        profile.put("shareRate", user.getShareRate());
-//        profile.put("registrationTime", user.getRegistrationTime());
-//
-//        return profile;
-//    }
-//
-//    // 修改用户个人资料
-//    public boolean editProfile(Long userId, String nickname, String gender, String description, String hobbies) {
-//        Optional<Users> userOptional = userRepository.findById(userId);
-//
-//        // 如果用户不存在,返回false
-//        if (userOptional.isEmpty()) {
-//            return false; // 用户不存在
-//        }
-//
-//        Users user = userOptional.get();
-//
-//        // 更新用户资料,只有传入值才会更新对应字段
-//        if (nickname != null) {
-//            user.setUsername(nickname);
-//        }
-//        if (gender != null) {
-//            user.setGender(gender);
-//        }
-//        if (description != null) {
-//            user.setDescription(description);
-//        }
-//        if (hobbies != null) {
-//            user.setHobbies(hobbies);
-//        }
-//
-//        // 保存更新后的用户信息
-//        userRepository.save(user);
-//
-//        return true; // 更新成功
-//    }
-//
-//    public Map<String, Object> calculateShareRate(Long userId) {
-//        // 查找用户
-//        Users user = userRepository.findById(userId).orElse(null);
-//        if (user == null) {
-//            return Map.of("status", "error", "message", "用户不存在");
-//        }
-//
-//        // 获取上传量和下载量
-//        Float uploadCount = user.getUploadCount();
-//        Float downloadCount = user.getDownloadCount();
-//
-//        // 计算分享率
-//        Float shareRate = 0f;  // 默认分享率为0
-//        if (downloadCount != 0) {
-//            shareRate = uploadCount / downloadCount;  // 分享率 = 上传量 / 下载量
-//        }
-//
-//        // 更新用户的分享率
-//        user.setShareRate(shareRate);
-//        userRepository.save(user);
-//
-//        // 返回结果
-//        return Map.of("status", "success", "message", "分享率计算成功", "shareRate", shareRate);
-//    }
-//
-//
-//    private static final String AVATAR_DIR = "uploads/avatarUrl/";
-//
-//    public Map<String, Object> uploadUserAvatar(Long userId, MultipartFile file) {
-//        Users user = userRepository.findById(userId)
-//                .orElseThrow(() -> new RuntimeException("用户不存在"));
-//
-//        try {
-//            String avatarUrl = saveAvatar(file, userId);
-//            user.setAvatarUrl(avatarUrl);
-//            userRepository.save(user);
-//
-//            Map<String, Object> response = new HashMap<>();
-//            response.put("status", "success");
-//            response.put("message", "头像上传成功");
-//            response.put("userId", user.getUserId());
-//            response.put("avatarUrl", avatarUrl);
-//            return response;
-//
-//        } catch (IOException e) {
-//            throw new RuntimeException("头像上传失败: " + e.getMessage());
-//        }
-//    }
-//
-//    // 保存头像文件并返回可访问 URL
-//    public String saveAvatar(MultipartFile file, Long userId) throws IOException {
-//        String originalFilename = file.getOriginalFilename();
-//        String extension = originalFilename.substring(originalFilename.lastIndexOf('.'));
-//        String fileName = userId + extension;  // 以用户ID作为文件名
-//        Path path = Paths.get(AVATAR_DIR + fileName);
-//        Files.createDirectories(path.getParent());
-//        Files.write(path, file.getBytes());
-//        return "/" + AVATAR_DIR + fileName;  // 返回相对URL路径
-//    }
-//
-//
-//
-//}
-
 package com.example.myproject.service;
-
+import cn.dev33.satoken.stp.StpUtil;
 import com.example.myproject.entity.FriendRelation;
 import com.example.myproject.entity.User;
 import com.example.myproject.entity.Users;
@@ -341,7 +12,7 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.web.multipart.MultipartFile;
-
+import lombok.RequiredArgsConstructor;
 import javax.servlet.http.HttpServletRequest;
 import java.io.File;
 import java.io.IOException;
@@ -353,8 +24,9 @@
 import java.time.LocalDateTime;
 import java.time.ZoneId;
 import java.util.*;
-
+import java.util.stream.Collectors;
 @Service
+@RequiredArgsConstructor
 public class UserService {
 
     @Autowired
@@ -367,9 +39,9 @@
     private FriendRelationRepository friendRelationRepository;
     private final LoginLogRepository loginLogRepository;
 
-    public UserService(LoginLogRepository loginLogRepository) {
-        this.loginLogRepository = loginLogRepository;
-    }
+//    public UserService(LoginLogRepository loginLogRepository) {
+//        this.loginLogRepository = loginLogRepository;
+//    }
 
     // 生成邀请码
     public Map<String, Object> generateInviteCode(Long userId) {
@@ -511,7 +183,7 @@
         if (!user.getPassword().equals(password)) {
             return "密码错误";
         }
-
+        StpUtil.login(user.getUserId());
         // 登录成功
         return "登录成功";
     }