看点资讯系统(前后端分离)简述及源码(一些心得)

2024-01-01 21:10

本文主要是介绍看点资讯系统(前后端分离)简述及源码(一些心得),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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);}
}

这篇关于看点资讯系统(前后端分离)简述及源码(一些心得)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/560525

相关文章

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Spring 中 BeanFactoryPostProcessor 的作用和示例源码分析

《Spring中BeanFactoryPostProcessor的作用和示例源码分析》Spring的BeanFactoryPostProcessor是容器初始化的扩展接口,允许在Bean实例化前... 目录一、概览1. 核心定位2. 核心功能详解3. 关键特性二、Spring 内置的 BeanFactory

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想