Spring Boot视频网站:安全与可扩展性设计
4 系统设计
 4.1系统概要设计
 视频网站系统并没有使用C/S结构,而是基于网络浏览器的方式去访问服务器,进而获取需要的数据信息,这种依靠浏览器进行数据访问的模式就是现在用得比较广泛的适用于广域网并且没有网速限制要求的B/S结构,图4.1就是开发出来的程序工作原理图。
 
图4.1 程序工作的原理图
 4.2系统功能结构设计
 下图就是系统功能结构图。
 
图4.1 系统功能结构图
 4.3数据库设计
 4.3.1数据库E-R图设计
 程序设计是离不开对应数据库的设计操作的,这样的做法就是减少数据对程序的依赖性,所以数据库的设计也是需要花费大量的日常时间来进行设计的,在设计中对程序开发需要存储的数据信息进行实体划分,先确认实体,然后设计实体的属性等操作,这种设计就是数据库设计里面不能少的必须有的E-R模型设计。为了降低程序设计的对应的数据库设计难度,开发人员也可以使用相应的工具来进行E-R模型设计,现在市面上设计E-R模型的工具有PowerDesigner建模工具,Navicat制作工具,还有微软的Visio绘图工具。为了简便起见,本程序在设计E-R模型的时候,就选用了微软的Visio这款功能强大,操作便利的绘图工具。
 下面就展示视频网站系统的实体E-R图。
 (1)下图就是公告实体E-R图
 
图4.7 公告实体E-R图
 (2)下图就是留言板实体E-R图
 
图4.8 留言板实体E-R图
 (3)下图就是视频类型实体E-R图
 
图4.9 视频类型实体E-R图
 4.3.2 数据库表结构设计
 本次程序开发选用的数据库管理工具是MySQL数据管理工具,使用它存放数据也需要创建程序对应的数据库文件,并命名刚创建的数据库文件,有了数据库也需要创建各种数据表来充实数据库,在数据表的创建中,不仅需要对数据表命名,也需要对数据表的字段进行设计,包括每个数据表里面需要设置的字段名称,字段对应的数据类型信息,字段的主键设置这个也是不可缺少的,因为每个数据表里面的主键就是标记着这个数据表跟其他数据表相区分的唯一标志。就相当于生活中的每个人都有姓名,但是上网搜索自己的名字,会发现全国上下有很多人的名字跟自己的名字一模一样,包括姓氏以及名字,区分每个人的唯一信息就是每个人的身份证号信息,主键在数据表里面也是起着这样的重要作用。下面就介绍本次开发的程序视频网站系统的数据表结构信息。
 表4.1 视频分享评论表
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 refid bigint(20) 否 关联表id
 userid bigint(20) 否 用户id
 nickname varchar(200) 是 NULL 用户名
 content longtext 否 评论内容
 reply longtext 是 NULL 回复内容
 表4.2 视频排名评论表
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 refid bigint(20) 否 关联表id
 userid bigint(20) 否 用户id
 nickname varchar(200) 是 NULL 用户名
 content longtext 否 评论内容
 reply longtext 是 NULL 回复内容
 表4.3 交流论坛
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 title varchar(200) 是 NULL 帖子标题
 content longtext 否 帖子内容
 parentid bigint(20) 是 NULL 父节点id
 userid bigint(20) 否 用户id
 username varchar(200) 是 NULL 用户名
 isdone varchar(200) 是 NULL 状态
 表4.4 留言板
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 userid bigint(20) 否 留言人id
 username varchar(200) 是 NULL 用户名
 content longtext 否 留言内容
 reply longtext 是 NULL 回复内容
 表4.5 平台公告
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 biaoti varchar(200) 是 NULL 标题
 neirong longtext 是 NULL 内容
 faburen varchar(200) 是 NULL 发布人
 faburiqi date 是 NULL 发布日期
 tupian varchar(200) 是 NULL 图片
 表4.6 视频分享
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 shipinmingcheng varchar(200) 是 NULL 视频名称
 leixing varchar(200) 是 NULL 类型
 shipinjianjie longtext 是 NULL 视频简介
 shipinneirong longtext 是 NULL 视频内容
 bofangshizhang varchar(200) 是 NULL 播放时长
 zaixianshipin varchar(200) 是 NULL 在线视频
 faburiqi date 是 NULL 发布日期
 fengmian varchar(200) 是 NULL 封面
 zhanghao varchar(200) 是 NULL 账号
 xingming varchar(200) 是 NULL 姓名
 sfsh varchar(200) 是 否 是否审核
 shhf longtext 是 NULL 审核回复
 thumbsupnum int(11) 是 0 赞
 crazilynum int(11) 是 0 踩
 clicktime datetime 是 NULL 最近点击时间
 clicknum int(11) 是 0 点击次数
 表4.7 视频类型
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 leixing varchar(200) 是 NULL 类型
 表4.8 视频排名
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 shipinmingcheng varchar(200) 是 NULL 视频名称
 leixing varchar(200) 是 NULL 类型
 shipinjianjie longtext 是 NULL 视频简介
 bofangliang int(11) 是 NULL 播放量
 bofangshizhang varchar(200) 是 NULL 播放时长
 zaixianshipin varchar(200) 是 NULL 在线视频
 fabuzhe varchar(200) 是 NULL 发布者
 faburiqi date 是 NULL 发布日期
 fengmian varchar(200) 是 NULL 封面
 thumbsupnum int(11) 是 0 赞
 crazilynum int(11) 是 0 踩
 表4.9 收藏表
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 userid bigint(20) 否 用户id
 refid bigint(20) 是 NULL 收藏id
 tablename varchar(200) 是 NULL 表名
 name varchar(200) 否 收藏名称
 picture varchar(200) 否 收藏图片
 表4.10 管理员表
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 username varchar(100) 否 用户名
 password varchar(100) 否 密码
 role varchar(100) 是 管理员 角色
 addtime timestamp 否 CURRENT_TIMESTAMP 新增时间
 表4.11 用户
 字段 类型 空 默认 注释
 id (主键) bigint(20) 否 主键
 addtime timestamp 否 CURRENT_TIMESTAMP 创建时间
 zhanghao varchar(200) 否 账号
 mima varchar(200) 否 密码
 xingming varchar(200) 否 姓名
 xingbie varchar(200) 是 NULL 性别
 shouji varchar(200) 是 NULL 手机
 youxiang varchar(200) 是 NULL 邮箱
 shenfenzheng varchar(200) 是 NULL 身份证
6系统测试
 为了保证所开发出来的系统质量过关,让所开发出来的系统具备可靠性并能够投入运行使用,这就需要进行系统开发的最后一个关键步骤,那就是系统测试。可以说系统测试就是对系统开发前面的步骤,比如系统分析与设计等进行复查。尽管在程序开发期间,人们一直很注意避免系统出错,但这样还是会让很多的潜在的系统缺陷不容易被人们肉眼察觉,只有经过反复不断地测试才能及时暴露系统的运行问题,这个时候进行系统问题的纠正就能真正避免财产损失,截止到目前,市面上还没有从根本上解决开发出的程序的正确性证明。所以发现系统的错误以及缺陷的重要手段还是要依赖于系统测试。
 6.1 本系统测试 
 本系统的测试结合了计算机的软件以及硬件系统,对程序的全部功能,还有程序的运行稳定性等性能上进行了测试,测试过程中也再次对程序配套数据库的连接问题进行了系统化地测试操作。接下来就选取系统的一些功能进行测试演示。
 6.1.1登录功能测试
 程序的登录界面实际上就是为了系统的安全,需要验证用户的身份信息而进行设置的,用户的身份信息就是依靠自己的账号,还有登录密码信息进行验证。用户的登录信息有一个存在问题,系统就会一直停在登录界面,并给出错误原因的提示。表6.1 就是登录功能测试的数据。
 表6.1 登录功能测试的数据
 用户名 密码 角色 结果
 aaa bbb 管理员角色 失败登录
 bbb aaa 管理员角色 失败登录
 aaa aaa 管理员角色 成功登录
6.1.2修改密码功能测试
 修改密码其实就是害怕用户的密码信息遭到泄露,导致系统的安全系数下降,因此,就要要求用户每个月修改一次密码。表6.2就是修改密码功能测试数据。
 表6.2 修改密码功能测试数据
 旧密码 新密码 结果
 aaa 修改失败
 bbb ccc 修改失败
 aaa ccc 修改成功
 6.2测试结果分析
 经过了程序开发的最后一个测试环节,对开发的程序软件视频网站系统也下了定论,在测试期间程序的功能能够跟最开始的用户需求文档保持一致性,程序的界面设计以及数据库设计也都是参照用户的需求完成设计的。另外,程序开发也充分解决了系统的升级以及长时间保持稳定运行的问题,说明该程序软件还是挺可靠的,进行验收上交也是达标的。总的说来,截止到目前,该视频网站系统功能可靠,有着简单的操作流程,能够从一定程度上解决数据信息操作方面出现的各种问题。
相关文章:
Spring Boot视频网站:安全与可扩展性设计
4 系统设计 4.1系统概要设计 视频网站系统并没有使用C/S结构,而是基于网络浏览器的方式去访问服务器,进而获取需要的数据信息,这种依靠浏览器进行数据访问的模式就是现在用得比较广泛的适用于广域网并且没有网速限制要求的B/S结构,…...
深入理解 Flutter 鸿蒙版的 Stack 布局:适配屏幕与层叠样式布局
目录 写在前面 什么是 Stack 布局? Stack 的基本用法 Stack 布局的核心概念 屏幕适配与 Stack 布局 使用 MediaQuery 获取屏幕尺寸 使用 LayoutBuilder 进行自适应布局 高级层叠样式布局示例 1. 照片展示与文字描述 2. 动态调整层叠布局 写在最后 写在前…...
JavaScript中Number相关特性
目录 非 VIP 用户可前往公众号“前端基地”进行免费阅读 数值范围 小数注意问题 NaN isNaN()判断是不是NaN JavaScript可以表示的进制 数值扩展 非 VIP 用户可前往公众号“前端基地”进行免费阅读 数值范围 数字类型主要涵盖整数与小数。在数值范围方面,存在特…...
Redis中String类型数据扩容原理分析
大家好,我是 V 哥。在 Java 中,我们有动态数组ArrayList,当插入新元素空间不足时,会进行扩容,好奇 Redis 中的 String 类型,C 语言又是怎样的实现策略,带着疑问,咱们来了解一下。 最…...
智能码二维码zhinengma.cn在供应链管理中有哪些优势?
智能码二维码在供应链管理中具有以下优势: 一、提高信息透明度 通过为每个产品或包装分配唯一的二维码,可以实现供应链各环节信息的实时共享。这有助于提高供应链的信息透明度,让各方都能及时了解产品的状态和位置。 二、加强追溯能力 智…...
代理商培训新策略:利用内部知识库提升培训效果
在当今竞争激烈的市场环境中,代理商作为企业与终端消费者之间的桥梁,其专业能力和服务质量直接影响着企业的市场表现和品牌形象。因此,对代理商进行系统而高效的培训,提升其业务技能和服务水平,成为企业不可忽视的重要…...
Redis 哨兵模式下DB库操作审计
Redis Sentinel集群环境 主机版本模式NodeSentinelredis-sentinel-node-06.2.12哨兵MasterYesredis-sentinel-node-16.2.12哨兵SlaveYesredis-sentinel-node-26.2.12哨兵SlaveYes 架构设计 命令行&程序验证 1、在redis-sentinel-node-1上使用redis-cli 连接redis-sentine…...
latex公式输入-矩阵
矩阵输入: 例1 \begin{bmatrix}1& 4&3 &5 \\\frac{1}{4} &1& \frac{1}{2}& 2\\\frac{1}{3}&2&1& \frac{5}{3} \\\frac{1}{5}& \frac{1}{2}& \frac{3}{5}&1 \end{bmatrix} 运行结果: 例2 \begin{bm…...
NSSCTF-WEB-easy_eval
目录 前言 正文 思路 序列化构造 后渗透 思路点1:Redis 思路2:蚁剑插件绕过disable_functinons 结尾 作者的其他文章 前言 说是easy,实际很difficult 正文 思路 <?php class A{public $code "";function __call($method,$args){//最后执行命令eval($th…...
交通目标识别数据集YOLO 模型 ui界面✓图片数量15000,xml和txt标签都有 11类 交通道路车辆行人红黄绿数据集 红绿灯数据集 交通信号数据集
YOLO交通目标识别 数据集 模型 ui界面 ✓图片数量15000,xml和txt标签都有; ✓class:biker,car,pedestrian,trafficLight,trafficLight-Green,trafficLight-GreenLeft, tr…...
买卖股票的最佳时机 题解
买卖股票的最佳时机 问题描述 给定一个数组 prices,其中 prices[i] 表示第 i 天的股票价格。你只能选择某一天买入股票,并选择未来的某一天卖出股票,设计一个算法来计算你所能获取的最大利润。 限制条件: 只能进行一次交易&…...
微信小程序路由跳转的区别及其常见的使用场景
在微信小程序中,页面路由跳转的实现有几种常用方式,不同的跳转方式适用于不同的使用场景。下面是几种跳转方法的区别及其在实际项目中的应用场景。 1. wx.navigateTo 简介:保留当前页面并跳转到指定页面,最多保留10个页面的历史记…...
麒麟桌面版v10 SP1以docker方式安装达梦数据库
安装docker 0.切换root用户(可以不切换,但要注意权限问题,我是用root) ymym-pc:~/桌面$ whoami ym ymym-pc:~/桌面$ sudo -i rootym-pc:~# whoami root rootym-pc:~# 1.查看系统版本 [rootlocalhost opt]# cat /etc/os-release…...
KNN的 k 设置的过大会有什么问题
在KNN(K-Nearest Neighbors)算法中,K值的选择对模型的性能和预测结果有着重要影响。如果K值设置得过大,可能会出现以下问题: 欠拟合:当K值过大时,模型会考虑过多的邻近点实例,甚至会…...
Star Tower:智能合约的安全基石与未来引领者
在区块链技术的快速发展中,智能合约作为新兴的应用形式,正逐渐成为区块链领域的重要组成部分。然而,智能合约的可靠性问题一直是用户最为关心的焦点之一。为此,Star Tower以其强大的技术实力和全面的安全保障措施,为智…...
2024-NewStarCTF-WEEK1
web headach3 提示head,抓包查看响应头,得到flag flag值:flag{You_Ar3_R3Ally_A_9ooD_d0ctor} 会赢吗 第一段:源码里找到第一段flag,ZmxhZ3tXQTB3 第二段:分析可知需要在控制台调用revealFlag函数向服务…...
大数据面试题整理——Zookeeper
系列文章目录 大数据面试题专栏点击进入 文章目录 系列文章目录大数据面试题专栏点击进入 1. 什么是 Zookeeper?2. Zookeeper 的特点有哪些?3. Zookeeper 的数据模型是怎样的?4. Zookeeper 的工作流程是怎样的?5. Zookeeper 如何…...
图书库存管理:Spring Boot驱动的进销存系统
1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及,互联网成为人们查找信息的重要场所,二十一世纪是信息的时代,所以信息的管理显得特别重要。因此,使用计算机来管理图书进销存管理系统的相关信息成为必然。开…...
用增结算数仓化改造:在/离线调度系统的构建与应用
导读 移动运营推广平台(OPS)承载着百度内部移动应用/移动搜索业务的用户增长预算的全流程结算线上化管控功能,为了解决用增业务发展规模扩大、原有技术架构老旧、无离线数仓系统等一系列的问题,针对全域结算数据启动了整体的架构…...
施磊C++高级进阶课程 | 学习笔记 | 博客汇总
施磊C高级进阶课程 | 学习笔记 | 博客汇总 施磊C | 进阶学习笔记 | 1.对象的应用优化、右值引用的优化-CSDN博客 施磊C | 进阶学习笔记 | 2.智能指针-CSDN博客 施磊C | 进阶学习笔记 | 3.绑定器和函数对象、lambda表达式-CSDN博客 施磊C | 进阶学习笔记 | 4.c11内容汇总、多…...
springboot 百货中心供应链管理系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,百货中心供应链管理系统被用户普遍使用,为方…...
【JavaEE】-- HTTP
1. HTTP是什么? HTTP(全称为"超文本传输协议")是一种应用非常广泛的应用层协议,HTTP是基于TCP协议的一种应用层协议。 应用层协议:是计算机网络协议栈中最高层的协议,它定义了运行在不同主机上…...
CocosCreator 之 JavaScript/TypeScript和Java的相互交互
引擎版本: 3.8.1 语言: JavaScript/TypeScript、C、Java 环境:Window 参考:Java原生反射机制 您好,我是鹤九日! 回顾 在上篇文章中:CocosCreator Android项目接入UnityAds 广告SDK。 我们简单讲…...
Matlab | matlab常用命令总结
常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...
Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战
说明:这是一个机器学习实战项目(附带数据代码文档),如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下,风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...
Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「storms…...
android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...
什么是VR全景技术
VR全景技术,全称为虚拟现实全景技术,是通过计算机图像模拟生成三维空间中的虚拟世界,使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验,结合图文、3D、音视频等多媒体元素…...
