基于SpringBoot+Vue的电影分享平台

81 篇文章 0 订阅
一、项目背景介绍:

您好,电影网站建设之项目背景与概要市网上电影订票服务平台将在地区范围内建立一个基于互联网的信息传播和便民服务平台,可通过互联网访问本系统实现网上查询、支付、订票等功能,免去市民排队购票的烦恼,减轻市民办理的复杂度。在为市民电影购票办理提供优质的技术支持服务的同时也为各大影院建立一个方便的、快捷的、安全的现代化的服务窗口。

二、项目技术简介:
  1. JAVA:Java是一门 面向对象编程语言 ,不仅 吸收了C++语言的各种优点 ,还摒弃了C++里难以理解的 多继承、指针 等概念,因此Java语言具有 功能强大和简单易用 两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。- Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来 简化Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。

三、系统功能模块介绍:

四、数据库设计:

1:collect(collect)

字段名

类型

默认值

列注释

id

bigint

NULL

收藏ID

user_id

bigint

NULL

用户ID

video_id

bigint

NULL

电影ID

2:‘管理员表’(manage)

字段名

类型

默认值

列注释

id

bigint

NULL

ID

user_name

varchar

NULL

用户名

pass_word

varchar

NULL

密码

photo_img

varchar

NULL

图片

name

varchar

NULL

名称

status

int

NULL

用户类型[0:超级管理员,1:普通管理员]

3:‘电影留言表’(messages)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

message_info

text

NULL

留言内容

user_id

bigint

NULL

用户ID

create_time

datetime

NULL

创建时间

msg_status

int

NULL

留言状态[0:未审核,1:审核通过,2:审核不通过]

video_id

bigint

NULL

电影ID

4:‘电影分类表’(types)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

type_name

varchar

NULL

分类名称

create_time

datetime

NULL

创建时间

5:‘用户表’(users)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

account

varchar

NULL

账号

password

varchar

NULL

密码

nick_name

varchar

NULL

姓名

tel

varchar

NULL

联系方式

head_img

varchar

NULL

头像

create_time

datetime

NULL

创建时间

6:‘电影评论表’(video_comment)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

user_id

bigint

NULL

用户ID

comment_info

text

NULL

评论内容

comment_status

int

NULL

评论状态[0:未审核,1:审核通过,2:审核不通过]

create_time

datetime

NULL

创建时间

video_id

bigint

NULL

电影ID

7:video_score(video_score)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

video_id

bigint

NULL

电影ID

user_id

bigint

NULL

用户ID

num

int

NULL

分数

8:‘电影表’(videos)

字段名

类型

默认值

列注释

id

bigint

NULL

主键ID

video_name

varchar

NULL

电影名称

video_img

varchar

NULL

电影封面图片

video_url

varchar

NULL

视频链接

video_download_url

varchar

NULL

下载链接

is_top

int

NULL

是否推荐[0:是,1:否]

type_id

bigint

NULL

分类ID

score

varchar

NULL

电影分数

info

text

NULL

电影介绍

detail

text

NULL

详情

五、功能模块:
  1. 电影管理:电影管理主要是对电影信息进行管理,包括图,视频等

  1. 用户首页:为用户推荐合适的电影

  1. 分类:通过不同的条件检索不同的电影

  1. 电影评论:用户可以在不同的电影下面进行评论,并对观看之后的电影进行评分

  1. 排行榜:根据电影评分的一个排行榜数据

六、代码示例:
电影管理
 @PostMapping("/page")
    public ReturnMsg page(@RequestBody VideosDTO videosDTO) {
        return ReturnMsg.ok(baseService.basePage(videosDTO));
    }

    @GetMapping("/all/types")
    public ReturnMsg allTypes() {
        List<BaseSelectEntity> list = new ArrayList<>();
        List<TypesDTO> dtos = typesService.list();
        for (TypesDTO dto : dtos) {
            BaseSelectEntity baseSelectEntity = new BaseSelectEntity();
            baseSelectEntity.setKey(dto.getId());
            baseSelectEntity.setValue(dto.getTypeName());
            list.add(baseSelectEntity);
        }
        return ReturnMsg.ok(list);
    }

用户首页
 @GetMapping("/banner")
    public ReturnMsg banner() {
        LambdaQueryWrapper<VideosDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(VideosDTO::getIsTop, 0);
        return ReturnMsg.ok(baseService.list(queryWrapper));
    }

    @GetMapping("/random")
    public ReturnMsg random() {
        List<VideosDTO> videosDTOS = baseService.list();
        Collections.shuffle(videosDTOS);
        return ReturnMsg.ok(videosDTOS.subList(0, 8));
    }

分类
 @PostMapping("/page")
    public ReturnMsg page(@RequestBody TypesDTO typesDTO) {
        return ReturnMsg.ok(baseService.basePage(typesDTO));
    }

电影评论
@PostMapping("/add/score")
    public ReturnMsg addScore(@RequestBody VideoScoreDTO videoScore) {
        VideoScoreDTO videoScore1 = new VideoScoreDTO();
        videoScore1.setUserId(videoScore.getUserId());
        videoScore1.setVideoId(videoScore.getVideoId());
        VideoScoreDTO one = videoScoreService.getOne(new QueryWrapper<>(videoScore1));
        if (one == null) {
            videoScoreService.save(videoScore);
            LambdaQueryWrapper<VideoScoreDTO> queryWrapper = new LambdaQueryWrapper<>();
            queryWrapper.eq(VideoScoreDTO::getVideoId, videoScore.getVideoId());
            List<VideoScoreDTO> scoreDTOS = videoScoreService.list(queryWrapper);
            int num = 0;
            for (VideoScoreDTO scoreDTO : scoreDTOS) {
                num += scoreDTO.getNum();
            }
            int i = num / scoreDTOS.size();
            VideosDTO videosDTO = new VideosDTO();
            videosDTO.setId(videoScore.getVideoId());
            videosDTO.setScore(i + "");
            baseService.updateById(videosDTO);
        }
        return ReturnMsg.ok();
    }

排行榜
@GetMapping("/rank/{num}")
    public ReturnMsg rank(@PathVariable("num") Integer num) {
        LambdaQueryWrapper<VideosDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.orderByDesc(VideosDTO::getScore).last("limit " + num);
        return ReturnMsg.ok(baseService.list(queryWrapper));
    }

七、项目总结:
本系统是以B/S模式为网络结构模式,在IDEA开发环境中,首先使用Java语言设计系统功能,使用MySQL数据库存储数据信息,然后使用连接语言实现前端Java语言与后台MySQL数据库的交互,再通过平台提供的Tomcat插件,将系统发布到Tomcat服务器上,最后用户可以选择浏览器打开网址使用本系统。本系统使用性能稳定可靠,在功能设计上,基本上达到预期的设计目标,并且根据系统测试结果可以得知,本系统现在是可以正常的被投入使用。

    如今是信息化的社会,随着大数据技术、人工智能、深度学习等新一代科学技术力量的出现,大大加快了各行业信息化建设的进程。我们应该努力学习新一代科学技术以及相关知识,不断提高自己的专业能力水平,设计和实现出一款能够顺应时代变化的,功能强大的信息管理系统。

八、源码获取:

 此源码非开源,若需要此源码可扫码添加微信进行咨询!

  • 19
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值