基于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 + Tomcat8.5 + Mysql + HBuilderX (Webstorm也 行)+ Eclispe (IntelliJ IDEA,Eclispe,MyEclispe,Sts都支 持)。
项目技术: Springboot + Maven + Mybatis + Vue , B/S 模式+ Maven等等
} 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
@RestController
@RequestMapping("/api/category")
@Api(tags = "共同前缀:/api/category", description = "CategoryController")
@Slf4j
public class CategoryController {
@Autowired
CategoryService categoryService;
@PostMapping
@ApiOperation("新增Category")
@PreAuthorize("hasAnyAuthority('ROLE_ADMIN')")
public ResponseObject post(@RequestBody Category category) {
log.info("新增Category");
if (category.getId() != null) {
throw new ControllerException("id必须为null");
} else if (category.getRank() == null) {
throw new ControllerException("rank不可为null");
} else if (category.getName() == null || category.getName().equals("")) {
throw new ControllerException("name不可为null,也不可为空字符串");
} else if (category.getParent_id() == null) {
throw new ControllerException("parent_id不可为null");
} else if (categoryService.selectByParent_idName(category.getParent_id(), category.getName()) != null) {
throw new ControllerException("name不可重复");
} else {
return new ResponseObject("200", "操作成功", categoryService.insert(category));
}
}
@PutMapping("/{id:[0-9]+}")
@ApiOperation("修改Category")
@PreAuthorize("hasAnyAuthority('ROLE_ADMIN')")
public ResponseObject putById(@PathVariable Integer id, @RequestBody HashMap<String, String> data) {
log.info("修改Category");
Category category = categoryService.selectById(id);
if (category == null) {
throw new ControllerException("使用该id的Category不存在");
} else if (categoryService.selectByParent_idName(category.getParent_id(), data.get("name")) != null) {
throw new ControllerException("同一个分类下的name不可重复");
} else {
category.setName(data.get("name"));
return new ResponseObject("200", "操作成功", categoryService.update(category));
}
}
@GetMapping
@ApiOperation("查询Category")
public ResponseObject getByParent_id(Integer rank, Integer parent_id) {
log.info("查询Category");
@RestController
@RequestMapping("/api/collection")
@Api(tags = "共同前缀:/api/collection", description = "CollectionController")
@Slf4j
public class CollectionController {
@Autowired
CollectionService collectionService;
@Autowired
UserService userService;
@Autowired
NovelService novelService;
@PostMapping
@ApiOperation("新增Collection")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(Collection collection) {
log.info("新增Collection");
if (collection.getId() != null) {
throw new ControllerException("id必须为null");
} else if (collection.getNovel_id() == null) {
throw new ControllerException("novel_id不可为null");
} else {
collection.setUser_id(userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal())
.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) {
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));
}
}
@GetMapping("/content")
@ApiOperation("查询Chapter的content")
public ResponseObject getContent(String content) {
log.info("查询Chapter的content");
if (content == null || content.equals("")) {
throw new ControllerException("content不可为null,也不可为空字符串");
} else {
try {
StringBuilder stringBuilder = new StringBuilder();
File file = new File(new File(ResourceUtils.getURL("src").getPath() + "main/resources/static/txt/"),
content);
FileReader fileReader = new FileReader(file);
char[] charArray = new char[1024];
int length = 0;
while ((length = fileReader.read(charArray)) != -1) {
stringBuilder.append(new String(charArray, 0, length));
}
fileReader.close();
return new ResponseObject("200", "操作成功", stringBuilder.toString());
} catch (Exception e) {
throw new ControllerException("找不到该章节的内容");
}
}
}
@PatchMapping("/content")
@ApiOperation("修改Chapter的content")
@PreAuthorize("isAuthenticated()")
public ResponseObject patchContent(String content, @RequestBody HashMap<String, String> data) {
log.info("修改Chapter的content");
log.info("查询Chapter的content");
if (content == null || content.equals("")) {
throw new ControllerException("content不可为null,也不可为空字符串");
} else {
try {
StringBuilder stringBuilder = new StringBuilder();
File file = new File(new File(ResourceUtils.getURL("src").getPath() + "main/resources/static/txt/"),
content);
FileReader fileReader = new FileReader(file);
char[] charArray = new char[1024];
int length = 0;
while ((length = fileReader.read(charArray)) != -1) {
stringBuilder.append(new String(charArray, 0, length));
}
fileReader.close();
return new ResponseObject("200", "操作成功", stringBuilder.toString());
} catch (Exception e) {
throw new ControllerException("找不到该章节的内容");
}
}
}
@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("找不到该章节的内容");
}
}
}
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else {
return new ResponseObject("200", "操作成功", collectionService.selectByNovel_id(novel_id).size());
}
}
}
@RestController
@RequestMapping("/api/recommend")
@Api(tags = "共同前缀:/api/recommend", description = "RecommendController")
@Slf4j
public class RecommendController {
@Autowired
RecommendService recommendService;
@Autowired
UserService userService;
@Autowired
NovelService novelService;
@PostMapping
@ApiOperation("新增Recommend")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Recommend recommend) {
log.info("新增Recommend");
if (recommend.getId() != null) {
@RestController
@RequestMapping("/api/novel")
@Api(tags = "共同前缀:/api/novel", description = "NovelController")
@Slf4j
public class NovelController {
@Autowired
NovelService novelService;
@Autowired
UserService userService;
@PostMapping
@ApiOperation("新增Novel")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Novel novel) {
log.info("新增Novel");
if (novel.getId() != null) {
throw new ControllerException("id必须为null");
} else if (novel.getUser_id() == null) {
throw new ControllerException("user_id不可为null");
} else if (novel.getCategory_id() == null) {
throw new ControllerException("category_id不可为null");
} else if (novel.getName() == null || novel.getName().equals("")) {
throw new ControllerException("name不可为null,也不可为空字符串");
} else if (novel.getSummary() == null || novel.getSummary().equals("")) {
throw new ControllerException("summary不可为null,也不可为空字符串");
} else if (novel.getImage() == null || novel.getImage().equals("")) {
throw new ControllerException("image不可为null,也不可为空字符串");
} else if (novel.getIs_complete() == null) {
throw new ControllerException("is_complete不可为null");
} else {
novel.setMultiplier(10000);
novel.setAddend(0);
return new ResponseObject("200", "操作成功", novelService.insert(novel));
}
@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);
}
}
}
}
} 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("")) {
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("该用户无权限修改小说头像");
}
}
}
}
}
//未认证异常处理器
@Component
@Slf4j
public class MyAuthenticationEntryPoint implements AuthenticationEntryPoint {
@Autowired
ObjectMapper objectMapper;
@Override
public void commence(HttpServletRequest request, HttpServletResponse response,
AuthenticationException authException) throws IOException, ServletException {
log.info("未认证,返回JSON格式的异常信息");
response.setStatus(401);
response.setCharacterEncoding("utf-8");
response.setContentType("application/json; charset=utf-8");
PrintWriter writer = response.getWriter();
writer.write(objectMapper.writeValueAsString(new ResponseObject("401", "未认证", null)));
writer.flush();
writer.close();
}
}
@RestController
@RequestMapping("/api")
@Api(tags = "共同前缀:/api", description = "AppController")
@Slf4j
public class AppController {
@RestController
@RequestMapping("/api/comment")
@Api(tags = "共同前缀:/api/comment", description = "CommentController")
@Slf4j
public class CommentController {
@Autowired
CommentService commentService;
@Autowired
UserService userService;
@PostMapping
@ApiOperation("新增Comment")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Comment comment) {
log.info("新增Comment");
if (comment.getId() != null) {
throw new ControllerException("id必须为null");
} else if (comment.getNovel_id() == null) {
throw new ControllerException("novel_id不可为null");
} else if (comment.getContent() == null || comment.getContent().equals("")) {
throw new ControllerException("content不可为null,也不可为空字符串");
} else {
comment.setUser_id(userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal())
.getId());
return new ResponseObject("200", "操作成功", commentService.insert(comment));
}
}
@GetMapping
@ApiOperation("查询Comment")
public ResponseObject get(Integer novel_id, Integer user_id) {
log.info("查询Comment");
if (novel_id != null && user_id != null) {
}
@RestController
@RequestMapping("/api")
@Api(tags = "共同前缀:/api", description = "AppController")
@Slf4j
public class AppController {
@Autowired
UserService userService;
@Autowired
NovelService novelService;
@GetMapping("/me")
@ApiOperation("查询Me")
@PreAuthorize("isAuthenticated()")
public ResponseObject getMe() {
log.info("查询Me");
return new ResponseObject("200", "操作成功", userService
.selectByUsername((String) SecurityContextHolder.getContext().getAuthentication().getPrincipal()));
}
}
@RestController
@RequestMapping("/api/novel")
@Api(tags = "共同前缀:/api/novel", description = "NovelController")
@Slf4j
public class NovelController {
@Autowired
NovelService novelService;
@Autowired
UserService userService;
@PostMapping
@ApiOperation("新增Novel")
@PreAuthorize("isAuthenticated()")
public ResponseObject post(@RequestBody Novel novel) {
log.info("新增Novel");
if (novel.getId() != null) {
throw new ControllerException("id必须为null");
} else if (novel.getUser_id() == null) {
throw new ControllerException("user_id不可为null");
} else if (novel.getCategory_id() == null) {
throw new ControllerException("category_id不可为null");
} else if (novel.getName() == null || novel.getName().equals("")) {
throw new ControllerException("name不可为null,也不可为空字符串");
} else if (novel.getSummary() == null || novel.getSummary().equals("")) {
StringBuilder stringBuilder = new StringBuilder();
File file = new File(new File(ResourceUtils.getURL("src").getPath() + "main/resources/static/txt/"),
content);
FileReader fileReader = new FileReader(file);
char[] charArray = new char[1024];
int length = 0;
while ((length = fileReader.read(charArray)) != -1) {
stringBuilder.append(new String(charArray, 0, length));
}
fileReader.close();
return new ResponseObject("200", "操作成功", stringBuilder.toString());
} catch (Exception e) {
throw new ControllerException("找不到该章节的内容");
}
}
}
@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("找不到该章节的内容");
}
}
}
}
@ApiOperation("查询Recommend")
public ResponseObject get(Integer novel_id, Integer user_id) {
log.info("查询Recommend");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} else if (user_id == null) {
throw new ControllerException("user_id不可为null");
} else {
return new ResponseObject("200", "操作成功", recommendService.selectByUser_idNovel_id(user_id, novel_id));
}
}
@DeleteMapping
@ApiOperation("删除Recommend")
@PreAuthorize("isAuthenticated()")
public ResponseObject delete(Integer novel_id, Integer user_id) {
log.info("删除Recommend");
if (novel_id == null) {
throw new ControllerException("novel_id不可为null");
} 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());
}
@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));
}
if (category == null) {
throw new ControllerException("使用该id的Category不存在");
} else if (categoryService.selectByParent_idName(category.getParent_id(), data.get("name")) != null) {
throw new ControllerException("同一个分类下的name不可重复");
} else {
category.setName(data.get("name"));
return new ResponseObject("200", "操作成功", categoryService.update(category));
}
}
@GetMapping
@ApiOperation("查询Category")
public ResponseObject getByParent_id(Integer rank, Integer parent_id) {
log.info("查询Category");
if (rank != null && parent_id != null) {
return new ResponseObject("200", "操作成功", categoryService.selectByRankParent_id(rank, parent_id));
} else if (rank != null && parent_id == null) {
return new ResponseObject("200", "操作成功", categoryService.selectByRank(rank));
} else if (rank == null && parent_id != null) {
return new ResponseObject("200", "操作成功", categoryService.selectByParent_id(parent_id));
} else {
throw new ControllerException("rank或者parent_id至少要有一个不为null");
}
}
@GetMapping("/{id:[0-9]+}")
@ApiOperation("查询Category")
public ResponseObject getById(@PathVariable Integer id) {
log.info("查询Category");
if (id != null) {
return new ResponseObject("200", "操作成功", categoryService.selectById(id));
} else {
throw new ControllerException("id不可为null");
}
}
}