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

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

相关文章

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

Python实现多路视频多窗口播放功能

《Python实现多路视频多窗口播放功能》这篇文章主要为大家详细介绍了Python实现多路视频多窗口播放功能的相关知识,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下... 目录一、python实现多路视频播放功能二、代码实现三、打包代码实现总结一、python实现多路视频播放功能服务端开

Python实现视频转换为音频的方法详解

《Python实现视频转换为音频的方法详解》这篇文章主要为大家详细Python如何将视频转换为音频并将音频文件保存到特定文件夹下,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5. 注意事项

Python利用自带模块实现屏幕像素高效操作

《Python利用自带模块实现屏幕像素高效操作》这篇文章主要为大家详细介绍了Python如何利用自带模块实现屏幕像素高效操作,文中的示例代码讲解详,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、获取屏幕放缩比例2、获取屏幕指定坐标处像素颜色3、一个简单的使用案例4、总结1、获取屏幕放缩比例from

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一