短视频后台管理系统之举报视频模块

2024-04-15 14:32

本文主要是介绍短视频后台管理系统之举报视频模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前端

  • 1.添加菜单
    //menu.jsp
<!-- 举报管理 start --><li class="nav-item "><a href="javascript:;" class="nav-link nav-toggle"><i class="icon-envelope-letter"></i><span class="title">举报管理</span><span class="arrow"></span></a><ul class="sub-menu"><li class="nav-item "><a href="<%=request.getContextPath() %>/video/showReportList.action" class="ajaxify nav-link "><span class="title">举报列表</span></a></li></ul></li>
  • 2.跳转出举报页面
  • //video.controller
  @GetMapping("/showReportList")public String showReportList() {return "video/reportList";}

而reportList.jsp中只有一个jqgrid的地址,调用jqgrid插件

  • 3.js操作
    首先把List进行初始化:
jQuery(document).ready(function() {debugger;UsersReportsList.init();
})

然后出使化过程中先调用后端查询举报信息列表

 url: hdnContextPath + "/video/reportList.action"

二、前端发送请求信息到后端
//video.controller中

@PostMapping("/reportList")
@ResponseBodypublic ResultByPage reportList(Integer page) {ResultByPage result = videoService.queryReportList(page, 10);return result;}

其中queryReportList的方法为
//VideoController.java

 @Overridepublic ResultByPage queryReportList(Integer page, Integer pageSize) {PageHelper.startPage(page, pageSize);List<Reports> reportsList = usersReportMapperCustom.selectAllVideoReport();PageInfo<Reports> pageList = new PageInfo<Reports>(reportsList);ResultByPage grid = new ResultByPage();grid.setTotal(pageList.getPages());grid.setRows(reportsList);grid.setPage(page);grid.setRecords(pageList.getTotal());return grid;}

//selectByExample(example)

<select id="selectAllVideoReport" resultType="com.atlantis.domain.vo.Reports" >select ur.id as id,ur.title as title,ur.content as content,ur.create_date as createDate,du.username as dealUsername,v.id as dealVideoId,v.video_desc as videoDesc,v.video_path as videoPath,v.status as status,u.username as submitUsernamefrom users_report ur left join users du on ur.deal_user_id = du.id left join videos v on ur.deal_video_id = v.id left join users u on ur.userid=u.idgroup by ur.create_date desc</select>

然后返回一个自定义的vo类,并封账为一个pageResult对象,返回到前端

三、前端接受后端发送的数据
1.拿到数据之后,jqgrid会进行渲染,按照列名,模块进行

 colNames: ['ID', '举报类型', '举报内容', '被举报人', '被举报视频id', '被举报视频', '视频状态', '提交用户', '举报日期', "操作"],  colModel: [  { name: 'id', index: 'id', width: 30, sortable: false, hidden: false },  { name: 'title', index: 'title', width: 30, sortable: false },{ name: 'content', index: 'content', width: 60, sortable: false },{ name: 'dealUsername', index: 'dealUsername', width: 20, sortable: false },{ name: 'dealVideoId', index: 'dealVideoId', width: 30, sortable: false },{ name: 'videoPath', index: 'videoPath', width: 30, sortable: false,formatter:function(cellvalue, options, rowObject) {var src = APIServer + cellvalue;var display = "<a href='" + src + "' target='_blank'>点我播放</a>"return display;}},{ name: 'status', index: 'status', width: 40, sortable: false, hidden: false,formatter:function(cellvalue, options, rowObject) {return cellvalue==1 ? '正常' : '禁播';}},{ name: 'submitUsername', index: 'submitUsername', width: 20, sortable: false },{ name: 'createDate', index: 'createDate', width: 40, sortable: false, hidden: false,formatter:function(cellvalue, options, rowObject) {var createTime = Common.formatTime(cellvalue,'yyyy-MM-dd HH:mm:ss');return createTime;}},{ name: '', index: '', width: 20, sortable: false, hidden: false,formatter:function(cellvalue, options, rowObject) {var button = '<button class="btn btn-outline blue-chambray" id="" οnclick=forbidVideo("' + rowObject.dealVideoId + '") style="padding: 1px 3px 1px 3px;">禁止播放</button>';return button;}}]

2.在点击禁播模块,会进行一个$.ajax的调用,并触发一个外面的方法

var forbidVideo = function(videoId) {var flag = window.confirm("是否禁播");if (!flag) {return;}$.ajax({url: $("#hdnContextPath").val() + "/video/forbidVideo.action?videoId=" + videoId,type: "POST",async: false,success: function(data) {if(data.status == 200 && data.msg == "OK") {alert("操作成功");var jqGrid = $("#usersReportsList");  jqGrid.jqGrid().trigger("reloadGrid");} else {console.log(JSON.stringify(data));}}})
}

然后调用forbidVideo这个方法,并把videoId传进去,利用定义的枚举类型,

 @PostMapping("/forbidVideo")@ResponseBodypublic ResultByJSON forbidVideo(String videoId) {videoService.updateVideoStatus(videoId, VideoStatusEnum.FORBID.value);return ResultByJSON.ok();}

//VideoServiceIml.java
里面的updateVideoStatus方法修改视频状态,把能播放状态改为不能播放状态

 @Overridepublic void updateVideoStatus(String videoId, Integer status) {Videos video = new Videos();video.setId(videoId);video.setStatus(status);videosMapper.updateByPrimaryKeySelective(video);}

这篇关于短视频后台管理系统之举报视频模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文