【开源】基于Vue和SpringBoot的快乐贩卖馆管理系统

在这里插入图片描述

项目编号: S 064 ,文末获取源码。 \color{red}{项目编号:S064,文末获取源码。} 项目编号:S064,文末获取源码。


目录

  • 一、摘要
    • 1.1 项目介绍
    • 1.2 项目录屏
  • 二、功能模块
    • 2.1 数据中心模块
    • 2.2 搞笑视频模块
    • 2.3 视频收藏模块
    • 2.4 视频评分模块
    • 2.5 视频交易模块
    • 2.6 视频好友模块
  • 三、系统设计
    • 3.1 用例设计
    • 3.2 数据库设计
      • 3.2.1 搞笑视频表
      • 3.2.2 视频收藏表
      • 3.2.3 视频评分表
      • 3.2.4 视频交易表
  • 四、系统展示
  • 五、核心代码
    • 5.1 查询搞笑视频
    • 5.2 加购搞笑视频
    • 5.3 搞笑视频打分
    • 5.4 搞笑视频收藏
    • 5.5 添加好友
  • 六、免责说明


一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的快乐贩卖馆管理系统,包含了视频模块、视频收藏模块、视频打分模块、视频交友模块、视频购物车模块和视频订单模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,快乐贩卖馆管理系统基于角色的访问控制,给视频管理员、普通用户使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏

源码下载


二、功能模块

随着互联网行业各种业务的兴起和发展,这一领域的市场竞争也日趋激烈。从视频网站的角度来看,主要的视频网站并未像许多人认为的那样在激烈的市场竞争中真正获利。相反,连续的损失是视频网站面临的最困难的问题。快乐贩卖馆系统是一套交易搞笑视频的系统,用户可以在其中自由交易搞笑视频。

快乐贩卖馆系统基于Java语言开发,采用前后端分离的技术架构,前端采用Vue.js,后端采用SpringBoot框架,采用MySQL数据库。

快乐贩卖馆系统的功能性需求主要包含数据中心模块、搞笑视频模块、视频收藏模块、视频评价模块、视频交易模块、视频好友模块这六大模块,系统是基于浏览器运行的web管理后端,其中各个模块详细说明如下。

2.1 数据中心模块

数据中心模块包含了快乐贩卖馆系统的系统基础配置,如登录用户的管理、运营公司组织架构的管理、用户菜单权限的管理、系统日志的管理、公用文件云盘的管理。
其中登录用户管理模块,由管理员负责运维工作,管理员可以对登录用户进行增加、删除、修改、查询操作。
组织架构,指的是高校的组织架构,该模块适用于管理这些组织架构的部门层级和教师的部门归属情况。
用户菜单权限管理模块,用于管理不同权限的用户,拥有哪些具体的菜单权限。
系统日志的管理,用于维护用户登入系统的记录,方便定位追踪用户的操作情况。
公用云盘管理模块,用于统一化维护快乐贩卖馆系统中的图片,如合同签订文件、合同照片等等。

2.2 搞笑视频模块

搞笑视频是快乐贩卖馆系统的核心,需要建立搞笑视频模块对其进行管理,搞笑视频的数据包括视频名称、视频介绍、视频价格、文件、排序值、备注、创建人、创建时间、更新人、更新时间,用户可以发布新的搞笑视频,管理员可以对用户发布的搞笑视频进行删除操作。

2.3 视频收藏模块

如果用户对某个视频非常满意,可以对其进行收藏,以便于后续快捷浏览,视频收藏的字段包括视频ID、视频名称、收藏时间、备注、创建人、创建时间、更新人、更新时间,用户可以对搞笑视频进行收藏操作,管理员可以查询用户的收藏数据。

2.4 视频评分模块

在快乐贩卖馆系统中,用户可以对搞笑视频进行评价,以此达到交互的效果,视频评分的数据包括视频ID、视频名称、视频文件、评分数值、创建人、创建时间、更新人、更新时间,用户可以对搞笑视频进行评分操作,管理员可以查询用户的评分数据。

2.5 视频交易模块

用户可以购买搞笑视频,购买需要消耗余额,余额来源自上传的搞笑视频,视频交易字段包括视频ID、视频名称、视频文件、付款状态、创建人、创建时间、更新人、更新时间,用户可以对搞笑视频进行下单、付款操作,管理员可以查询用户的交易数据。

2.6 视频好友模块

如果用户对视频的发布者很感兴趣,可以添加单向好友,方便留档,视频好友的字段包括所属人、好友ID、好友昵称、好友手机、创建人、创建时间、更新人、更新时间,用户可以添加搞笑视频的创作者,管理员可以查询用户添加的好友数据。

在这里插入图片描述


三、系统设计

3.1 用例设计

在这里插入图片描述

3.2 数据库设计

3.2.1 搞笑视频表

在这里插入图片描述

3.2.2 视频收藏表

在这里插入图片描述

3.2.3 视频评分表

在这里插入图片描述

3.2.4 视频交易表

在这里插入图片描述


四、系统展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


五、核心代码

5.1 查询搞笑视频

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询搞笑视频")
public Result<IPage<FunnyVideo>> getByPage(@ModelAttribute FunnyVideo funnyVideo ,@ModelAttribute PageVo page){
    QueryWrapper<FunnyVideo> qw = new QueryWrapper<>();
    User currUser = securityUtil.getCurrUser();
    if(!ZwzNullUtils.isNull(funnyVideo.getTitle())) {
        qw.like("title",funnyVideo.getTitle());
    }
    if(!ZwzNullUtils.isNull(funnyVideo.getContent())) {
        qw.like("content",funnyVideo.getContent());
    }
    IPage<FunnyVideo> data = iFunnyVideoService.page(PageUtil.initMpPage(page),qw);
    for (FunnyVideo vo : data.getRecords()) {
        // 好友状态
        QueryWrapper<FunnyOrder> orderQw = new QueryWrapper<>();
        orderQw.eq("video_id",vo.getId());
        orderQw.eq("user_id",currUser.getId());
        vo.setStatus1(iFunnyOrderService.count(orderQw));
        // 好友状态
        QueryWrapper<Friends> friQw = new QueryWrapper<>();
        friQw.eq("my_id",currUser.getId());
        friQw.eq("user_id",vo.getUserId());
        vo.setStatus2(iFriendsService.count(friQw));
        // 收藏状态
        QueryWrapper<FunnyCollect> fcQw = new QueryWrapper<>();
        fcQw.eq("video_id",vo.getId());
        fcQw.eq("user_id",currUser.getId());
        vo.setStatus3(iFunnyCollectService.count(fcQw));
    }
    return new ResultUtil<IPage<FunnyVideo>>().setData(data);
}

5.2 加购搞笑视频

@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "新增单条搞笑视频订单")
public Result<FunnyOrder> addOne(@RequestParam String id){
    FunnyVideo v = iFunnyVideoService.getById(id);
    if(v == null) {
        return ResultUtil.error("视频不存在");
    }
    User currUser = securityUtil.getCurrUser();
    QueryWrapper<FunnyOrder> orderQw = new QueryWrapper<>();
    orderQw.eq("video_id",v.getId());
    orderQw.eq("user_id", currUser.getId());
    FunnyOrder order = iFunnyOrderService.getOne(orderQw);
    if(order != null) {
        if(Objects.equals("加购",order.getStatus1())) {
            return ResultUtil.error("您已加购,请下单");
        } else {
            return ResultUtil.error("您已购买,无需重复购买");
        }
    }
    FunnyOrder o = new FunnyOrder();
    o.setVideoId(v.getId());
    o.setTitle(v.getTitle());
    o.setContent(v.getContent());
    o.setFileUrl(v.getFileUrl());
    o.setPrice(v.getPrice());
    o.setUserId(currUser.getId());
    o.setUserName(currUser.getNickname());
    o.setStatus1("加购");
    o.setStatus2("未付款");
    iFunnyOrderService.saveOrUpdate(o);
    return ResultUtil.success();
}

5.3 搞笑视频打分

@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "新增单条搞笑视频评分")
public Result<Object> addOne(@RequestParam String id,@RequestParam BigDecimal grade){
    FunnyVideo video = iFunnyVideoService.getById(id);
    if(video == null) {
        return ResultUtil.error("视频不存在");
    }
    User currUser = securityUtil.getCurrUser();
    FunnyGrade c = new FunnyGrade();
    c.setVideoId(video.getId());
    c.setTitle(video.getTitle());
    c.setContent(video.getContent());
    c.setFileUrl(video.getFileUrl());
    c.setUserId(currUser.getId());
    c.setUserName(currUser.getNickname());
    c.setGrade(grade);
    c.setTime(DateUtil.now());
    iFunnyGradeService.saveOrUpdate(c);
    return ResultUtil.success();
}

5.4 搞笑视频收藏

@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "新增单条搞笑视频收藏")
public Result<Object> addOne(@RequestParam String id){
    FunnyVideo video = iFunnyVideoService.getById(id);
    if(video == null) {
        return ResultUtil.error("视频不存在");
    }
    User currUser = securityUtil.getCurrUser();
    QueryWrapper<FunnyCollect> qw = new QueryWrapper<>();
    qw.eq("video_id",video.getId());
    qw.eq("user_id",currUser.getId());
    if(iFunnyCollectService.count(qw) < 1L) {
        FunnyCollect c = new FunnyCollect();
        c.setVideoId(video.getId());
        c.setTitle(video.getTitle());
        c.setContent(video.getContent());
        c.setFileUrl(video.getFileUrl());
        c.setUserId(currUser.getId());
        c.setUserName(currUser.getNickname());
        c.setTime(DateUtil.now());
        iFunnyCollectService.saveOrUpdate(c);
    }
    return ResultUtil.success();
}

5.5 添加好友

@RequestMapping(value = "/addOne", method = RequestMethod.GET)
@ApiOperation(value = "添加单条好友")
public Result<Friends> addOne(@RequestParam String id){
    FunnyVideo v = iFunnyVideoService.getById(id);
    if(v == null) {
        return ResultUtil.error("视频不存在");
    }
    User currUser = securityUtil.getCurrUser();
    if(Objects.equals(v.getUserId(),currUser.getId())) {
        return ResultUtil.error("不能添加自己为好友!");
    }
    QueryWrapper<Friends> qw = new QueryWrapper<>();
    qw.eq("my_id", currUser.getId());
    qw.eq("user_id",v.getUserId());
    if(iFriendsService.count(qw) > 0L) {
        return ResultUtil.error("已添加,无需重复添加!");
    }
    User user = iUserService.getById(v.getUserId());
    if(user != null) {
        Friends f = new Friends();
        f.setMyId(currUser.getId());
        f.setUserId(user.getId());
        f.setUserName(user.getNickname());
        f.setMobile(user.getMobile());
        f.setAddTime(DateUtil.now());
        iFriendsService.saveOrUpdate(f);
    }
    return ResultUtil.success();
}

六、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/149969.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux常用的磁盘使用情况命令汇总

1、查看分区使用百分比 df -h 2、查看指定目录磁盘使用情况 du -hac --max-depth1 /opt 参数&#xff1a;-a 查看所有文件&#xff0c;-c 汇总统计&#xff0c;max-depth1 查看深度为1&#xff0c;2级目录不再统计。 3、常用统计命令汇总

一键帮您解决win11最新版画图工具难用问题!

&#x1f984;个人主页:修修修也 ⚙️操作环境:Windows 11 正文 自从win11更新后,新版的画图工具变得非常难用,如: 使用橡皮擦后露出背版马赛克 框住某部分拖动移动时背景露出马赛克剪贴板上图片信息无法直接插入到画图板 目前没有一个好一些的能够在软件内部解决这些问题的方…

参考意义大。4+巨噬细胞相关生信思路,简单易复现。

今天给同学们分享一篇生信文章“Angiogenesis regulators S100A4, SPARC and SPP1 correlate with macrophage infiltration and are prognostic biomarkers in colon and rectal cancers”&#xff0c;这篇文章发表在Front Oncol期刊上&#xff0c;影响因子为4.7。 结果解读&a…

软件测试个人求职简历该怎么写,模板在这里

1、个人资料 姓 名&#xff1a;xxx 性 别&#xff1a;x 手机号码&#xff1a;138888888xx 邮 箱&#xff1a; xxx 学 历&#xff1a;本科 专 业&#xff1a;电子商务 英 语&#xff1a;四级 当前工作&#xff1a;测试工程师 从业时间&#xff1a;4年 期望薪资&#xff1a;…

HDFS入门--学习笔记

1&#xff0c;大数据介绍 定义 数据指的是&#xff1a;一种可以被鉴别的、对客观事件进行记录的符号&#xff0c;除了可以是最简单的 数字外&#xff0c;也可以是各类符号、文字、图像、声音等。 通俗地说&#xff0c;数据就是对人类的行为及发生事件的一种记录。 存在的价值…

使用群晖虚拟机快速搭建黑群晖并在公网移动端环境下使用软件

文章目录 前言本教程解决的问题是&#xff1a;按照本教程方法操作后&#xff0c;达到的效果是前排提醒&#xff1a; 1. 搭建群晖虚拟机1.1 下载黑群晖文件vmvare虚拟机安装包1.2 安装VMware虚拟机&#xff1a;1.3 解压黑群晖虚拟机文件1.4 虚拟机初始化1.5 没有搜索到黑群晖的解…

Mysql中的索引与事务和B树的知识补充

索引与事务和B树的知识补充 一.索引1.概念2.作用3.使用场景4.使用 二.事务1.为什么使用事务2.事务的概念3.使用3.1脏读问题3.2不可重复读3.3 幻读问题3.4解决3.5 使用代码 三.B树的知识补充1.B树2.B树 一.索引 1.概念 索引是一种特殊的文件&#xff0c;包含着对数据表里所有记…

QGIS之二十栅格数据定义投影

效果 步骤 1、准备数据 2、定义投影 Qgis工具箱中搜索“投影” 指定投影坐标系&#xff0c;例如EPSG&#xff1a;4549 运行 3、结果 查看属性

【Qt-23】基于QCharts绘制曲线图

一、QChart简介 QChart是Qt中专门用于绘制图表的模块&#xff0c;支持折线图、柱状图、饼图等常见类型。其主要组成部分有&#xff1a; QChart&#xff1a;整个图表的容器&#xff0c;管理图表中的所有数据和图形属性QChartView&#xff1a;继承自QGraphicsView&#xff0c;用于…

day2324_jdbc

今日内容 零、 复习昨日 一、作业 二、SQL注入 三、PreparedStatement 四、事务 五、DBUtil 零、 复习昨日 一、引言 1.1 如何操作数据库 使用客户端工具访问数据库&#xff0c;需要手工建立连接&#xff0c;输入用户名和密码登录&#xff0c;编写 SQL 语句&#xff0c;点击执行…

基于MS16F3211芯片的触摸控制灯的状态变化和亮度控制(11.15)

1.任务所需实现基本功能 关机状态时白灯亮蓝灯灭&#xff0c;此时长按按键无反应&#xff0c;白灯亮度降低的状态&#xff0c;蓝灯保持灭的状态。点按按键一次&#xff0c;白灯熄灭&#xff0c;蓝灯亮此时W引脚控制的灯亮。继续点按按键。蓝灯亮&#xff0c;此时W引脚控制的灯…

9.3 【MySQL】系统表空间

了解完了独立表空间的基本结构&#xff0c;系统表空间的结构也就好理解多了&#xff0c;系统表空间的结构和独立表空间基本类似&#xff0c;只不过由于整个MySQL进程只有一个系统表空间&#xff0c;在系统表空间中会额外记录一些有关整个系统信息的页面&#xff0c;所以会比独立…

python之 flask 框架(2)项目拆分的 执行逻辑

项目的结构图 app.py # 导入__init__.py 比较特殊 from APP import create_appapp create_app() if __name__ __main__:app.run(debugTrue)init.py # __inti__.py # 初始化文件&#xff0c;创建Flask应用 from flask import Flask from .views import bluedef create_ap…

多媒体播放器Infuse mac中文版软件特点

Infuse mac是一款多媒体播放器应用&#xff0c;它支持播放多种格式的视频文件、音频文件和图片文件&#xff0c;并且可以通过AIrPlay将媒体内容投放到其他设备上。Infuse还支持在线视频流媒体播放和本地网络共享&#xff0c;用户可以通过它来访问家庭网络上的媒体文件。 Infuse…

【银行测试】支付功能、支付平台、支持渠道如何测试?

有朋友提问&#xff1a;作为一个支付平台&#xff0c;接入了快钱、易宝或直连银行等多家的渠道&#xff0c;内在的产品流程是自己的。业内有什么比较好的测试办法&#xff0c;来测试各渠道及其支持的银行通道呢&#xff1f; 作为产品&#xff0c;我自己办了十几张银行卡方便测…

Python数据容器(字典)

字典 1.字典的定义2.字典数据的获取3.字典的嵌套4.嵌套字典的内容获取5.字典的常用操作6.常用操作总结7.遍历字典8.练习 1.字典的定义 同样使用{}&#xff0c;不过存储的元素是一个一个的&#xff1a;键值对&#xff0c;语法如下 # 定义字典字面量 {key:value,key:value,...,…

2年博士后|心外医生赴美国耶鲁大学开展研究

G医生决定放弃申报CSC&#xff0c;改为自费出国&#xff0c;并在美国密歇根大学安娜堡分校和耶鲁大学两所名校中选择了更为出名的后者。因为不是CSC出资&#xff0c;G医生得以通过签证&#xff0c;顺利出国&#xff0c;实现了在世界知名高校从事2年博士后的个人职业规划目标。 …

IDEA安装配置SceneBuilder

1、下载 SceneBuilder 地址&#xff1a; Scene Builder - Gluon ​​​​​​​ Scene Builder | JavaFX中文官方网站 选择符合自己系统版本&#xff0c;JAVA版本的下载 2、安装SceneBuilder 执行下载的 SceneBuilder 安装程序&#xff0c;并按照安装向导的指示进行…

Oracle(17)Managing Roles

目录 一、基础知识 1、基础介绍 2、Predefined Roles 预定义的角色 3、各种角色的介绍 二、基础操作 1、创建角色 2、修改用户默认role 3、回收role 4、删除role 5、为角色授权 6、授予角色给用户 7、查看用户包含的角色&#xff1a; 8、查看角色所包含的权限 9、…

深入解析JavaScript中的变量作用域与声明提升

JS中的变量作用域 背景&#xff1a; ​ 之前做js逆向的时候&#xff0c;有一个网站很有意思&#xff0c;就是先出现对其赋值&#xff0c;但是后来的变量赋值没有对其发生修改&#xff0c;决定说一下js中的作用域问题. 全局作用域&#xff1a; ​ 全局作用域的变量可以在任何…