山东大学项目实训-创新实训-法律文书专家系统-项目报告(七)
项目实训博客:MongoDB 驱动的对话管理模块开发
作为项目中对话管理模块的开发者,我聚焦于 用户登录注册、对话历史保存、收藏对话 核心功能,基于 MongoRepository
实现与 MongoDB 的高效交互。以下是开发实践的深度总结:
一、功能定位与技术栈
1. 核心职责
- 用户基础服务:实现登录、注册功能,为系统提供身份验证基础
- 对话数据管理:保存用户交互历史、支持收藏对话持久化
- 技术选型:
- 数据库:MongoDB(灵活 schema 适配对话场景)
- 持久层:
MongoRepository
(简化 CRUD 操作) - 认证:JWT(Token 生成与解析)
二.准备工作
一、添加 Maven 依赖
在 pom.xml
中添加 Spring Data MongoDB 依赖:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
二、配置 MongoDB 连接信息
在 application.properties
或 application.yml
中配置 MongoDB 连接参数:
spring.data.mongodb.uri=mongodb://localhost:27017/test
三. MongoDB 交互设计
用户表(users
集合)
@Document(collection = "users")
public class User {private String useriId; private String username; // 账号private String password; // 密码
}
对话历史表(dialog_db 集合)
@Document(collection = "dialog_db")// 集合名
public class Dialog {private String username;private Integer role;private String content;private LocalDateTime updateTime;
}
收藏对话表(dialog_collection
集合)
@Document(collection = "dialog_collection")
//收藏的对话
public class DialogCollection {private String title; //文件标题private String username; //用户名private Integer role; //角色编号private String content; //内容private LocalDateTime updateTime; //更新时间
}
创建 Repository 接口
继承 MongoRepository<T, ID>
接口,泛型参数分别为实体类和主键类型:
import org.springframework.data.mongodb.repository.MongoRepository;public interface CollectionRepository extends MongoRepository<DialogCollection,String> {//删除一条收藏void deleteByTitleAndUsername(String title,String username);//根据文件名或用户名查询收藏的对话List<DialogCollection> findByTitleOrUsername(String title, String username);//根据文件名或用户名删除所有收藏对话void deleteAllByTitleOrUsername(String title, String username);
}public interface DialogHistoryRepository extends MongoRepository<Dialog, String> {//根据用户名查询List<Dialog> findAllByUsername(String username);// 可以在此添加自定义查询方法,不过基本的 CRUD 方法已由父接口提供// 根据用户名查询最新的几条记录List<Dialog> findTopNumberByUsernameOrderByUpdateTimeDesc(String username, Integer number);// 根据用户名删除所有记录void deleteAllByUsername(String username);
}public interface LoginRepository extends MongoRepository<User, String> {/*** 根据用户名和密码查询用户*/User findByUsername(String username);
}public interface RegisterRepository extends MongoRepository<User, String> {// 根据用户名查询用户User findUserByUsername(String username);
}
四. 使用示例
根据登录注册 历史对话 收藏对话 我设计了四个Controller分别控制一块功能,并设计了Service接口和实现类
Controller中接受前端的参数 交由Service实现类处理 其中 每个ServiceImpl注入了对应的Repository对象 用于操作数据
4.1 登录功能
@PostMapping("/login")
public Result login(@RequestBody LoginRequest loginRequest) {String username = loginRequest.getUsername();String password = loginRequest.getPassword();User user = loginService.login(username, password);if(user == null){return Result.error("登录失败");}//登录成功就发放jwt令牌HashMap<String, Object> claims = new HashMap<>();claims.put("userId", user.getUserId());claims.put("username", username);String jwtToken = JwtUtils.generateJwt(claims);System.out.println("本次登录产生的jwt令牌:{}" + jwtToken);UserVO userVO = UserVO.builder().userId(user.getUserId()).username(username).token(jwtToken).build();return Result.success(userVO);
其中loginService.login()方法用于登录校验
@Override
public User login(String username, String password) {User user = loginRepository.findByUsername(username);//判断是否存在if(user == null){//log.info("用户不存在");throw new ServiceException(CODE_500,"用户不存在");}//判断密码是否正确if(!user.getPassword().equals(password)){//log.info("密码错误");throw new ServiceException(CODE_500,"密码错误");}return user;
}
根据用户名密码去user集合查询 如果没有就返回“账号不存在”,否则返回User对象
4.2 注册功能
注册功能的逻辑是先校验是否符合规则 如果符合就创建User对象 并保存至集合中
@Override
public User register(RegisterDTO registerDTO) {//正则表达式校验//用户名 数字 字母 3-10位//密码 数字 字母 6-10位String usernamePattern = "^[a-zA-Z0-9]{3,10}$";String passwordPattern = "^[a-zA-Z0-9]{6,10}$";String username = registerDTO.getUsername();String password = registerDTO.getPassword();//判断用户名是否已经存在User user = registerRepository.findUserByUsername(username);if(user != null){throw new ServiceException(500,"用户名已存在");}if(!username.matches(usernamePattern)){throw new ServiceException(500,"用户名格式错误");}else if(!password.matches(passwordPattern)){throw new ServiceException(500,"密码格式错误");}else {user = new User();BeanUtils.copyProperties(registerDTO,user);long userId = autoIncrementUserIdUtils.getNextId("userSeq");user.setUserId((int) userId);//保存到数据库中registerRepository.save(user);}return user;
}
4.3 历史对话 和 收藏对话 的相关功能
思路都是一样的:通过DialogRepository进行增删改查
五. 待优化点
问题类型 | 具体问题 | 优化方案 |
---|---|---|
性能优化 | 对话历史查询效率较低 | 增加username + createTime 复合索引 |
安全加固 | 密码传输存在明文风险 | 全面升级加密策略,强化传输层防护 |
功能完善 | 收藏记录存在重复问题 | 添加username + title 唯一约束索引 |
展望与成长
后续将推进优化方案落地,验证索引添加、加密策略升级等对系统的实际增益。同时,持续挖掘 MongoDB 在法律对话场景的潜力,探索如对话内容分词检索、收藏标签化管理等功能扩展,借助数据库特性深化业务价值。
通过本次开发,团队熟练掌握 MongoRepository
简化数据库操作的优势,理解非关系型数据库在灵活业务场景的适配性,也清晰认知数据模块从功能实现到体验打磨的完整链路。未来,将以更成熟的技术实践,为法律科技类系统打造更高效、更安全、更贴合用户需求的数据交互体系。