基于javaweb+mysql的springboot在线小说阅读系统(前后端分离+java+vue+springboot+ssm+mysql+maven)
私信源码获取及调试交流
运行环境
Java≥8、MySQL≥5.7、Node.js≥10
开发工具
后端:eclipse/idea/myeclipse/sts等均可配置运行
前端:WebStorm/VSCode/HBuilderX等均可
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
基于javaweb+mysql的SpringBoot在线小说阅读系统(前后端分离+java+vue+springboot+ssm+mysql+maven)
一、项目简述
本系统功能包括: 普通用户端登录注册,小说的分类,日榜,月榜,年榜, 小说的阅读,分章节,小说的评论,收藏,推荐等等,以 及后台小说的维护,上架,编辑等等。
二、项目运行
环境配置: Jdk1.8 + Mysql + HBuilderX (Webstorm也 行)+ Eclispe (IntelliJ IDEA,Eclispe,MyEclispe,Sts都支 持)。
项目技术: Springboot + Maven + Mybatis + Vue , B/S 模式+ Maven等等
throw new ControllerException("不可自己关注自己");
} else if (followService.selectByFollower_idFollowing_id(follow.getFollower_id(),
follow.getFollowing_id()) != null) {
throw new ControllerException("该用户已经关注过了,不可重复关注");
} else {
return new ResponseObject("200", "操作成功", followService.insert(follow));
}
}
}
@GetMapping
@ApiOperation("查询Follow")
public ResponseObject get(Integer follower_id, Integer following_id) {
log.info("查询Follow");
if (follower_id != null && following_id != null) {
return new ResponseObject("200", "操作成功",
followService.selectByFollower_idFollowing_id(follower_id, following_id));
} else if (follower_id != null && following_id == null) {
return new ResponseObject("200", "操作成功", userService.selectByFollower_id(follower_id));
} else if (follower_id == null && following_id != null) {
return new ResponseObject("200", "操作成功", userService.selectByFollowing_id(following_id));
} else {
throw new ControllerException("follower_id与following_id不可同时为null");
}
}
@DeleteMapping
@ApiOperation("删除Follow")
@PreAuthorize("isAuthenticated()")
public ResponseObject delete(Integer following_id) {
log.info("删除Follow");
if (following_id == null) {
throw new ControllerException("following_id不可为null");
} else {
Integer follower_id = userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal())
.getId();
Follow follow = followService.selectByFollower_idFollowing_id(follower_id, following_id);
if (follow == null) {
throw new ControllerException("该用户未关注,无法取消关注");
} else {
followService.deleteById(follow.getId());
return new ResponseObject("200", "操作成功", null);
}
}
}
}
}
}
@GetMapping("/count")
@ApiOperation("查询Recommend")
public ResponseObject getCount(Integer novel_id) {
log.info("查询Recommend");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else {
return new ResponseObject("200", "操作成功", recommendService.selectByNovel_id(novel_id).size());
}
}
@GetMapping("/novel")
@ApiOperation("查询Recommend的Novel")
public ResponseObject getNovel(Integer user_id) {
log.info("查询Recommend的Novel");
if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", novelService.selectByUser_idOfRecommend(user_id));
}
}
}
}
}
}
}
@RestController
@RequestMapping("/api/chapter")
@Api(tags = "共同前缀:/api/chapter", description = "ChapterController")
@Slf4j
public class ChapterController {
@Autowired
ChapterService chapterService;
@PostMapping
@ApiOperation("新增Chapter")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody HashMap<String, String> data) {
log.info("新增Chapter");
if (data.get("title") == null || data.get("title").equals("")) {
throw new ControllerException("volume_id不可为null");
} else if (data.get("volume_id") == null || data.get("volume_id").equals("")) {
throw new ControllerException("title不可为null,也不可为空字符串");
} else if (data.get("chapterContent") == null || data.get("chapterContent").equals("")) {
throw new ControllerException("chapterContent不可为null,也不可为空字符串");
public ResponseObject Rank(Integer day_count, Integer limit_count) {
if (day_count == null) {
throw new ControllerException("day_count不可为null");
} else if (limit_count == null) {
throw new ControllerException("limit_count不可为null");
} else {
Date date = new Date(new Date().getTime() - (long) 1000 * 60 * 60 * 24 * day_count);
return new ResponseObject("200", "操作成功",
novelService.selectByRank(MyUtils.simpleDateFormat.format(date), limit_count));
}
}
@PostMapping("/image")
@ApiOperation("上传image")
@PreAuthorize("isAuthenticated()")
public ResponseObject postImage(MultipartFile file) throws Exception {
log.info("上传image");
if (file == null) {
throw new ControllerException("上传的文件不可为null");
} else {
String fileName = file.getOriginalFilename();
String suffix = fileName.substring(fileName.lastIndexOf("."));
if (!suffix.equals(".png")) {
throw new RuntimeException("上传的文件必须为png文件");
} else {
String directoryPath = ResourceUtils.getURL("src").getPath() + "main/resources/static/images/";
File directory = new File(directoryPath);
if (!directory.exists()) {
directory.mkdirs();
}
String newFileName = new Date().getTime() + ".png";
File file2 = new File(directory, newFileName);
if (!file2.exists()) {
file2.createNewFile();
}
// 保存文件
file.transferTo(file2);
return new ResponseObject("200", "操作成功", newFileName);
}
}
}
@PatchMapping("/image")
@ApiOperation("修改image")
@PreAuthorize("isAuthenticated()")
public ResponseObject patchImage(@RequestBody HashMap<String, String> data) {
log.info("修改image");
String image = data.get("image");
String novel_idString = data.get("novel_id");
if (image == null || image.equals("")) {
throw new ControllerException("image不可为null,也不可为空字符串");
} else if (novel_idString == null || novel_idString.equals("")) {
@RestController
@RequestMapping("/api/user")
@Api(tags = "共同前缀:/api/user", description = "UserController")
@Slf4j
public class UserController {
@Autowired
UserService userService;
@PostMapping
@ApiOperation("新增User")
public ResponseObject post(String username, String password) {
log.info("新增User");
if (username == null || username.equals("")) {
throw new ControllerException("username不可为null,也不可为空字符串");
} else if (password == null || password.equals("")) {
throw new ControllerException("password不可为null,也不可为空字符串");
} else if (userService.selectByUsername(username) != null) {
throw new ControllerException("该username已被使用");
} else {
User user = new User();
user.setUsername(username);
user.setPassword(password);
user.setRole("VIP1");
user.setNickname(new Date().getTime() + "");
user.setImage("default_user_image.png");
user.setEmail("该用户没有填写邮箱");
user.setPhone("该用户没有填写手机号码");
user.setProfile("该用户没有填写个人简介");
return new ResponseObject("200", "操作成功", userService.insert(user));
}
}
@GetMapping("/{id:[0-9]+}")
@ApiOperation("查询User")
if (novel_id != null && user_id != null) {
return new ResponseObject("200", "操作成功", collectionService.selectByUser_idNovel_id(user_id, novel_id));
} else if (novel_id != null && user_id == null) {
return new ResponseObject("200", "操作成功", collectionService.selectByNovel_id(novel_id));
} else if (novel_id == null && user_id != null) {
return new ResponseObject("200", "操作成功", collectionService.selectByUser_id(user_id));
} else {
throw new ControllerException("novel_id与user_id不可同时为null");
}
}
@GetMapping("/novel")
@ApiOperation("查询Collection的Novel")
public ResponseObject getNovel(Integer user_id) {
log.info("查询Collection的Novel");
if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", novelService.selectByUser_idOfCollection(user_id));
}
}
@DeleteMapping
@ApiOperation("删除Collection")
@PreAuthorize("isAuthenticated()")
public ResponseObject delete(Integer novel_id, Integer user_id) {
log.info("删除Collection");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
Collection collection = collectionService.selectByUser_idNovel_id(user_id, novel_id);
if (collection == null) {
throw new ControllerException("该用户还未收藏该小说,无法取消收藏");
} else {
User user = userService.selectByUsername(
(String) SecurityContextHolder.getContext().getAuthentication().getPrincipal());
if (user.getId() == user_id || user.getRole().equals("ADMIN")) {
collectionService.deleteById(collection.getId());
return new ResponseObject("200", "操作成功", null);
} else {
throw new ControllerException("该用户无权限取消收藏");
}
}
}
}
@GetMapping("/count")
@PatchMapping("/content")
@ApiOperation("修改Chapter的content")
@PreAuthorize("isAuthenticated()")
public ResponseObject patchContent(String content, @RequestBody HashMap<String, String> data) {
log.info("修改Chapter的content");
if (content == null || content.equals("")) {
throw new ControllerException("content不可为null,也不可为空字符串");
} else if (data.get("chapterContent") == null || data.get("chapterContent").equals("")) {
throw new ControllerException("chapterContent不可为null,也不可为空字符串");
} else {
try {
File file = new File(new File(ResourceUtils.getURL("src").getPath() + "main/resources/static/txt/"),
content);
FileWriter fileWriter = new FileWriter(file);
fileWriter.write(data.get("chapterContent"));
fileWriter.flush();
fileWriter.close();
return new ResponseObject("200", "操作成功", data.get("chapterContent"));
} catch (Exception e) {
throw new ControllerException("找不到该章节的内容");
}
}
}
}
@RestController
@RequestMapping("/api/follow")
@Api(tags = "共同前缀:/api/follow", description = "FollowController")
@Slf4j
public class FollowController {
@Autowired
UserService userService;
@Autowired
FollowService followService;
@PostMapping
@ApiOperation("新增Follow")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Follow follow) {
log.info("新增Follow");
System.out.println(follow);
if (follow.getId() != null) {
throw new ControllerException("id必须为null");
} else if (follow.getFollower_id() != null) {
throw new ControllerException("follower_id必须为null");
} else if (follow.getFollowing_id() == null) {
throw new ControllerException("following_id不可为null");
} else {
follow.setFollower_id(userService
String directoryPath = ResourceUtils.getURL("src").getPath() + "main/resources/static/images/";
File directory = new File(directoryPath);
if (!directory.exists()) {
directory.mkdirs();
}
String newFileName = new Date().getTime() + ".png";
File file2 = new File(directory, newFileName);
if (!file2.exists()) {
file2.createNewFile();
}
// 保存文件
file.transferTo(file2);
return new ResponseObject("200", "操作成功", newFileName);
}
}
}
@PatchMapping("/image")
@ApiOperation("修改image")
@PreAuthorize("isAuthenticated()")
public ResponseObject patchImage(@RequestBody HashMap<String, String> data) {
log.info("修改image");
String image = data.get("image");
String novel_idString = data.get("novel_id");
if (image == null || image.equals("")) {
throw new ControllerException("image不可为null,也不可为空字符串");
} else if (novel_idString == null || novel_idString.equals("")) {
throw new ControllerException("novel_id不可为null");
} else {
Integer novel_id = Integer.parseInt(novel_idString);
Novel novel = novelService.selectById(novel_id);
if (novel == null) {
throw new ControllerException("根据novel_id查询出来的novel为null");
} else {
User user = userService.selectByUsername(
(String) SecurityContextHolder.getContext().getAuthentication().getPrincipal());
if (user.getId() == novel.getUser_id() || user.getRole().equals("ADMIN")) {
novel.setImage(image);
return new ResponseObject("200", "操作成功", novelService.update(novel));
} else {
throw new ControllerException("该用户无权限修改小说头像");
}
}
}
}
}
@GetMapping
@ApiOperation("查询Chapter")
public ResponseObject get(Integer volume_id) {
log.info("查询Chapter");
if (volume_id == null) {
throw new ControllerException("volume_id不可为null");
} else {
return new ResponseObject("200", "操作成功", chapterService.selectByVolume_id(volume_id));
}
}
@GetMapping("/{id:[0-9]+}/last")
@ApiOperation("查询上一章的Chapter")
public ResponseObject getLast(@PathVariable Integer id) {
log.info("查询上一章的Chapter");
if (id == null) {
throw new ControllerException("id不可为null");
} else {
Chapter chapter = chapterService.selectById(id);
if (chapter == null) {
throw new ControllerException("该id无法查找到chapter");
} else {
return new ResponseObject("200", "操作成功",
chapterService.selectLastByVolume_idId(chapter.getVolume_id(), chapter.getId()));
}
}
}
@GetMapping("/{id:[0-9]+}/next")
@ApiOperation("查询下一章的Chapter")
public ResponseObject getNext(@PathVariable Integer id) {
log.info("查询下一章的Chapter");
if (id == null) {
throw new ControllerException("id不可为null");
} else {
Chapter chapter = chapterService.selectById(id);
if (chapter == null) {
throw new ControllerException("该id无法查找到chapter");
} else {
return new ResponseObject("200", "操作成功",
chapterService.selectNextByVolume_idId(chapter.getVolume_id(), chapter.getId()));
} else if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
Recommend recommend = recommendService.selectByUser_idNovel_id(user_id, novel_id);
if (recommend == null) {
throw new ControllerException("该用户还未推荐该小说,无法取消推荐");
} else {
User user = userService.selectByUsername(
(String) SecurityContextHolder.getContext().getAuthentication().getPrincipal());
if (user.getId() == recommend.getUser_id() || user.getRole().equals("ADMIN")) {
recommendService.deleteById(recommend.getId());
return new ResponseObject("200", "操作成功", null);
} else {
throw new ControllerException("该用户无权限取消推荐");
}
}
}
}
@GetMapping("/count")
@ApiOperation("查询Recommend")
public ResponseObject getCount(Integer novel_id) {
log.info("查询Recommend");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else {
return new ResponseObject("200", "操作成功", recommendService.selectByNovel_id(novel_id).size());
}
}
@GetMapping("/novel")
@ApiOperation("查询Recommend的Novel")
public ResponseObject getNovel(Integer user_id) {
log.info("查询Recommend的Novel");
if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", novelService.selectByUser_idOfRecommend(user_id));
}
}
}
//无权限异常处理器
@Component
@Slf4j
public class MyAccessDeniedHandler implements AccessDeniedHandler {
@Autowired
ObjectMapper objectMapper;
@Override
public void handle(HttpServletRequest request, HttpServletResponse response,
AccessDeniedException accessDeniedException) throws IOException, ServletException {
log.info("已认证无权限,返回JSON格式的异常信息");
response.setStatus(403);
response.setCharacterEncoding("utf-8");
response.setContentType("application/json; charset=utf-8");
PrintWriter writer = response.getWriter();
writer.write(objectMapper.writeValueAsString(new ResponseObject("403", "已认证无权限", null)));
writer.flush();
writer.close();
}
}
}
@GetMapping("/{id:[0-9]+}")
@ApiOperation("查询User")
public ResponseObject getById(@PathVariable Integer id) {
log.info("查询User");
return new ResponseObject("200", "操作成功", userService.selectById(id));
}
@PutMapping
@ApiOperation("修改User")
@PreAuthorize("isAuthenticated()")
public ResponseObject put(User user) {
log.info("修改User");
if (user.getNickname() == null || user.getNickname().equals("")) {
throw new ControllerException("nickname不可为null,也不可为空字符串");
} else if (user.getProfile() == null || user.getProfile().equals("")) {
throw new ControllerException("profile不可为null,也不可为空字符串");
} else if (user.getPhone() == null || user.getPhone().equals("")) {
throw new ControllerException("phone不可为null,也不可为空字符串");
} else if (user.getEmail() == null || user.getEmail().equals("")) {
throw new ControllerException("email不可为null,也不可为空字符串");
} else {
User user2 = userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal());
user2.setNickname(user.getNickname());
user2.setProfile(user.getProfile());
user2.setPhone(user.getPhone());
user2.setEmail(user.getEmail());
return new ResponseObject("200", "操作成功", userService.update(user2));
}
}
}
@PostMapping
@ApiOperation("新增Follow")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Follow follow) {
log.info("新增Follow");
System.out.println(follow);
if (follow.getId() != null) {
throw new ControllerException("id必须为null");
} else if (follow.getFollower_id() != null) {
throw new ControllerException("follower_id必须为null");
} else if (follow.getFollowing_id() == null) {
throw new ControllerException("following_id不可为null");
} else {
follow.setFollower_id(userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal())
.getId());
if (follow.getFollower_id() == follow.getFollowing_id()) {
throw new ControllerException("不可自己关注自己");
} else if (followService.selectByFollower_idFollowing_id(follow.getFollower_id(),
follow.getFollowing_id()) != null) {
throw new ControllerException("该用户已经关注过了,不可重复关注");
} else {
return new ResponseObject("200", "操作成功", followService.insert(follow));
}
}
}
@GetMapping
@ApiOperation("查询Follow")
public ResponseObject get(Integer follower_id, Integer following_id) {
log.info("查询Follow");
if (follower_id != null && following_id != null) {
return new ResponseObject("200", "操作成功",
followService.selectByFollower_idFollowing_id(follower_id, following_id));
} else if (follower_id != null && following_id == null) {
return new ResponseObject("200", "操作成功", userService.selectByFollower_id(follower_id));
} else if (follower_id == null && following_id != null) {
return new ResponseObject("200", "操作成功", userService.selectByFollowing_id(following_id));
} else {
@GetMapping("/{id:[0-9]+}/last")
@ApiOperation("查询上一章的Chapter")
public ResponseObject getLast(@PathVariable Integer id) {
log.info("查询上一章的Chapter");
if (id == null) {
throw new ControllerException("id不可为null");
} else {
Chapter chapter = chapterService.selectById(id);
if (chapter == null) {
throw new ControllerException("该id无法查找到chapter");
} else {
return new ResponseObject("200", "操作成功",
chapterService.selectLastByVolume_idId(chapter.getVolume_id(), chapter.getId()));
}
}
}
@GetMapping("/{id:[0-9]+}/next")
@ApiOperation("查询下一章的Chapter")
public ResponseObject getNext(@PathVariable Integer id) {
log.info("查询下一章的Chapter");
if (id == null) {
throw new ControllerException("id不可为null");
} else {
Chapter chapter = chapterService.selectById(id);
if (chapter == null) {
throw new ControllerException("该id无法查找到chapter");
} else {
return new ResponseObject("200", "操作成功",
chapterService.selectNextByVolume_idId(chapter.getVolume_id(), chapter.getId()));
}
}
}
@GetMapping("/{id:[0-9]+}")
@ApiOperation("查询Chapter")
public ResponseObject getById(@PathVariable Integer id) {
log.info("查询Chapter");
if (id == null) {
throw new ControllerException("id不可为null");
} else {
return new ResponseObject("200", "操作成功", chapterService.selectById(id));
}
@DeleteMapping
@ApiOperation("删除Collection")
@PreAuthorize("isAuthenticated()")
public ResponseObject delete(Integer novel_id, Integer user_id) {
log.info("删除Collection");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
Collection collection = collectionService.selectByUser_idNovel_id(user_id, novel_id);
if (collection == null) {
throw new ControllerException("该用户还未收藏该小说,无法取消收藏");
} else {
User user = userService.selectByUsername(
(String) SecurityContextHolder.getContext().getAuthentication().getPrincipal());
if (user.getId() == user_id || user.getRole().equals("ADMIN")) {
collectionService.deleteById(collection.getId());
return new ResponseObject("200", "操作成功", null);
} else {
throw new ControllerException("该用户无权限取消收藏");
}
}
}
}
@GetMapping("/count")
@ApiOperation("查询Collection")
public ResponseObject getCount(Integer novel_id) {
log.info("查询Collection");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else {
return new ResponseObject("200", "操作成功", collectionService.selectByNovel_id(novel_id).size());
}
}
}
.getId());
if (collectionService.selectByUser_idNovel_id(collection.getUser_id(), collection.getNovel_id()) != null) {
throw new ControllerException("该用户已经收藏过该小说了,不可重复收藏");
} else {
return new ResponseObject("200", "操作成功", collectionService.insert(collection));
}
}
}
@GetMapping
@ApiOperation("查询Collection")
public ResponseObject get(Integer novel_id, Integer user_id) {
log.info("查询Collection");
if (novel_id != null && user_id != null) {
return new ResponseObject("200", "操作成功", collectionService.selectByUser_idNovel_id(user_id, novel_id));
} else if (novel_id != null && user_id == null) {
return new ResponseObject("200", "操作成功", collectionService.selectByNovel_id(novel_id));
} else if (novel_id == null && user_id != null) {
return new ResponseObject("200", "操作成功", collectionService.selectByUser_id(user_id));
} else {
throw new ControllerException("novel_id与user_id不可同时为null");
}
}
@GetMapping("/novel")
@ApiOperation("查询Collection的Novel")
public ResponseObject getNovel(Integer user_id) {
log.info("查询Collection的Novel");
if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", novelService.selectByUser_idOfCollection(user_id));
}
}
@DeleteMapping
@ApiOperation("删除Collection")
@PreAuthorize("isAuthenticated()")
public ResponseObject delete(Integer novel_id, Integer user_id) {
log.info("删除Collection");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
@GetMapping("/count")
@ApiOperation("查询Recommend")
public ResponseObject getCount(Integer novel_id) {
log.info("查询Recommend");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else {
return new ResponseObject("200", "操作成功", recommendService.selectByNovel_id(novel_id).size());
}
}
@GetMapping("/novel")
@ApiOperation("查询Recommend的Novel")
public ResponseObject getNovel(Integer user_id) {
log.info("查询Recommend的Novel");
if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", novelService.selectByUser_idOfRecommend(user_id));
}
}
}