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

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

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类

STL经典案例(四)——实验室预约综合管理系统(项目涉及知识点很全面,内容有点多,耐心看完会有收获的!)

项目干货满满,内容有点过多,看起来可能会有点卡。系统提示读完超过俩小时,建议分多篇发布,我觉得分篇就不完整了,失去了这个项目的灵魂 一、需求分析 高校实验室预约管理系统包括三种不同身份:管理员、实验室教师、学生 管理员:给学生和实验室教师创建账号并分发 实验室教师:审核学生的预约申请 学生:申请使用实验室 高校实验室包括:超景深实验室(可容纳10人)、大数据实验室(可容纳20人)、物联网实验