本文主要是介绍看点资讯系统(前后端分离)简述及源码(一些心得),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.项目提出背景:
随着互联网的发展,大数据时代的来临,大量的数据踊跃而出,它们被包装成各种各样的形式,比如文章,视频,新闻等,它们也被分为不同的类别,像军事,娱乐,财经等,它们分布在各种媒体网站和APP中。百度新闻,一点资讯和今日头条都已经将这些功能非常的完善了。但是随着数据越来越多,需要呈现的内容要更加的简洁方便,于是创建一个看点资讯系统。 看点资讯系统是以新闻发布,资讯展示,信息管理为主要功能的网站,提供了图文、音乐、视频等一体的资讯展示功能。主要包括前台显示和后台管理两大部分,我们采用的是前后台分离的技术,这样的话,后台不需要多大的改动,而前台可根据不同客户的需求去修改定制。
2相关技术:
springboot:
简化新Spring应⽤的初始搭建以及开发过程.
有几个特点是:能创建独⽴的Spring应⽤程序 简化Maven配置 ⾃动配置Spring ★约定优于配置(按照约定)
spring:
高性能,易于测试,可复用性强,简单轻量.
模块化比较好内置单元测试,支持MVC,能很好地支持相关协议。
SpringMVC:
SpringMVC框架是基于MVC模式,使用Java语言开发实现的一个轻量级 Web 框架。通过简单的配置,就能够让SpringMVC框架和Spring容器一起使用,SpringMVC提供了一整套完善的组件,可以直接使用。
它的优点: 框架的配置简单又不失灵活性 代码的可重用性很高 可扩展性好
springdata-jpa:
Spring Data JPA 是 Spring 基于 ORM 框架、JPA 规范的基础上封装的⼀套JPA应⽤框架,可使开发者⽤极简的代码即可实现对数据的访问和操作。它提供了包括增删改查等在内的常⽤功能,使⽤ Spring Data JPA 可以极⼤提⾼开发效率!因为项目中使用了JPA,可以在实体类中配置完关系映射后,让JPA根据配置自动创建表.
数据库:
mysql是一个免费开源的关系型数据库管理系统 特点: MySQL 是一个真正的多用户、多线程 SQL 数据库服务器。它能够快速、有效 和安全的处理大量的数据。 MySQL 的使用是非常简单的,主要目标是快速、健壮和易用 在任何平台上都能使用,占用的空间相对较小
文档管理:
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务,配置生成的在线API文档。方便前台查看!
3具备功能:
用户模块 角色模块 资讯模块 类别模块 评论模块
部分源码:
资讯功能:
public class ArticleController {@Autowiredprivate ArticleService service;//发布资讯或者编辑资讯@ApiOperation(value = "发布资讯",notes = "传递一个json格式的资讯对象的字符串")@PostMapping("/saveArticle")public Result saveArticle(@RequestBody Article article) {service.saveOrUpdateArticle(article);return Result.success(article);}//分页查询所有资讯@ApiOperation(value = "分页查询所有资讯",notes = "不需要参数")@GetMapping("/findAllArticle")public Result findAllArticle() {Page<Article> page = service.findAll(0, 10);return Result.success(page);}//根据ID删除多个资讯信息@ApiOperation(value = "删除多个资讯",notes = "输入被删除的资讯ID(集合或者数组类型的字符串)")@DeleteMapping("/deleteArticle")public Result deleteArticle(@RequestBody List<Long> ids) {service.deleteArticleInBatch(ids);return Result.success("删除成功");}//更新资讯状态(未审核0,审核通过1,审核失败2)@ApiOperation(value = "更新资讯状态",notes = "输入要更新状态的资讯ID")@PutMapping("/updateArticleStatus")public Result updateArticleStatus(Long id,String status) {service.updateArticleStatus(id, status);return Result.success("更新状态成功");}//根据资讯id查找资讯的所有评论,并分页显示评论}
分类功能:
@Api(tags = "分类模块")
@RestController
public class CategoryController {@Autowiredprivate CategoryService service;//查询所有分类@ApiOperation(value = "查询所有分类",notes = "不需要输入参数")@GetMapping("/findAllCategory")public Result findAllCategory() {Page<Category> ct = service.findAll(0, 3);return Result.success(ct);}//添加分类@ApiOperation(value = "添加分类",notes = "传递一个json格式的分类对象的字符串")@PostMapping("/saveCategory")public Result saveCategory(@RequestBody Category category) {service.saveOrUpdateCategory(category);return Result.success("添加成功");}//根据ID删除多个分类信息@ApiOperation(value = "删除多个分类信息",notes = "输入被删除的分类ID(集合或数组类型的字符串)")@DeleteMapping("/deleteAllCategory")public Result deleteCategory(@RequestBody List<Long> ids) {service.deleteCategoryInBatch(ids);return Result.success("删除成功");}//按序号升序查询所有分类,并进行分页@ApiOperation(value = "按序号升序查询所有分类",notes = "不需要输入参数")@GetMapping("/findAllCategorySortByNo")public Result findAllCategorySortByNo() {Page<Category> page = service.findAllSortbyno(0, 5);return Result.success(page);}//更新分类的序号@ApiOperation(value = "更新分类序号",notes = "需要更新序号的分类ID")@PutMapping("/updateNo")public Result updateCategoryNo(Long id,int no) {service.updateCategoryNo(id, no);return Result.success("更新成功");}
}
评论功能
@Api(tags = "评论模块")
@RestController
public class CommentController {@Autowiredprivate CommentService service;//分页获取所有评论@ApiOperation(value = "查询所有评论",notes = "不需要输入参数")@GetMapping("/findAllComment")public Result findAllComment() {Page<Comment> cm = service.findAll(0, 5);return Result.success(cm);}//新增评论或者更新评论@ApiOperation(value = "添加评论",notes = "传递一个json格式的评论对象的字符串")@PostMapping("/saveComment")public Result saveComment(@RequestBody Comment comment) {service.saveOrUpdateComment(comment);return Result.success("添加成功");}//批量删除评论@ApiOperation(value = "删除多个评论",notes = "输入被删除的评论ID(集合或数组类型的字符串)")@DeleteMapping("/deleteAllComment")public Result deleteComment(@RequestBody List<Long> ids) {service.deleteCommentInBatch(ids);return Result.success("删除成功");}//根据资讯id分页获取所有评论}
角色模块
@Api(tags = "角色模块")
@RestController
public class RoleController {@Autowiredprivate RoleService service;//注册一个角色@ApiOperation(value = "注册角色",notes = "传递一个json格式的角色对象的字符串")@PostMapping("/saveRole")public Result saveRole(@RequestBody Role role) {//调用service层方法完成注册的业务逻辑service.saveOrUpdateRole(role);return Result.success(role);}//根据角色名称查找具体的角色信息@ApiOperation(value = "查询角色",notes = "传递一个字符串型的角色名称")@ApiImplicitParams(@ApiImplicitParam(name = "name",value = "角色名称"))@GetMapping("/findRole")public Result findRoleByName(String name) {//调用service层方法完成注册的业务逻辑Role role = service.findRoleByName(name);if(role==null) {throw new ServiceException(ResultCode.USER_NOT_EXIST);}return Result.success(role);}// 查找全部的用户信息@ApiOperation(value = "分页查询全部角色",notes = "一个整数类型的页码数")@ApiImplicitParams({@ApiImplicitParam(value = "需要查看第几页的内容",name = "pageIndex")})@GetMapping("/findAllRole")public Result findAllRole(int pageIndex) {Page<Role> page =service.findAll(pageIndex, 1);return Result.success(page);}//通过ID删除单个角色信息@ApiOperation(value = "删除单个角色信息",notes = "传递被删除角色的ID")@DeleteMapping("/delete/{roleId}")public Result deleteRoleById(@PathVariable("roleId") Long roleId) {service.deleteRoleById(roleId);return Result.success("删除成功");}//通过ID删除多个角色信息@ApiOperation(value = "删除多个角色信息",notes = "传递被删除角色的ID(集合或者数组格式的字符串)")@DeleteMapping("/deleteAll")public Result deleteRole(@RequestBody List<Long> ids) {System.out.println(ids);service.deleteRoleInBatch(ids);return Result.success("删除成功");}
}
用户功能
@Api(tags = "用户模块")
@RestController
public class UserController {@Autowiredprivate UserService service;//添加用户@ApiOperation(value="注册用户",notes="传递一个json格式的用户对象的字符串")@PostMapping("/saveUser")public Result addUser(@RequestBody User user) {service.saveOrUpdateUser(user);return Result.success(user);}//根据ID查询用户信息@ApiOperation(value = "根据ID查询用户",notes = "要查询的用户ID")@ApiImplicitParams(@ApiImplicitParam(name = "ID",value = "用户ID"))@GetMapping("/findUserById/{userId}")public Result findUserById(@PathVariable("userId") Long userId) {//调用service层方法完成注册的业务逻辑User user = service.findUserById(userId);if(user==null) {throw new ServiceException(ResultCode.USER_NOT_EXIST);}return Result.success(user);}//根据用户名查询用户@ApiOperation(value = "根据Name查询用户",notes = "要查询的用户名")@ApiImplicitParams(@ApiImplicitParam(name = "name",value = "用户名"))@GetMapping("/findUserByName")public Result findUserByName(String name) {//调用service层方法完成注册的业务逻辑User user = service.findUserByUsername(name);if(user==null) {throw new ServiceException(ResultCode.USER_NOT_EXIST);}return Result.success(user);}//查询所有的用户信息@ApiOperation(value="查询所有用户",notes = "不需要传入参数")@GetMapping("/findAllUser")public Result findAllUser(){Page<User> page = service.getAll(0, 3);return Result.success(page);}//根据ID删除单个用户信息@ApiOperation(value = "删除单个用户",notes = "被删除用户的ID")@DeleteMapping("/deleteUser/{userId}")public Result deleteUserById(@PathVariable("userId") Long userId) {service.deleteUserById(userId);return Result.success("删除成功");}//根据ID删除多个用户信息@ApiOperation(value = "删除多个用户",notes = "被删除用户的ID(集合或数组格式的字符串)")@DeleteMapping("/deleteAllUser")public Result deleteUser(@RequestBody List<Long> ids) {service.deleteUserInBatch(ids);return Result.success("删除成功");}//根据ID修改用户的状态@ApiOperation(value = "修改用户状态",notes = "要修改的用户ID")@PutMapping("/updateUser/{userId}/{status}")public Result updateUserById(@PathVariable("userId") Long userId,@PathVariable("status") String status) {service.updateUserStatus(userId,status);return Result.success("更新成功");}//用户登录@ApiOperation(value = "用户登录",notes = "输入用户名和密码")@PostMapping("/loginUser")public Result loginUser(String username,String password) {User user = service.login(username, password);if(user==null||!user.getPassword().equals(password)) {throw new ServiceException(ResultCode.USER_LOGIN_ERROR);}//判断用户状态(正常/禁用)if(user.getStatus().equals("1")) {throw new ServiceException(ResultCode.USER_STATUS_ERROR);}return Result.success(user);}
}
这篇关于看点资讯系统(前后端分离)简述及源码(一些心得)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!