基于springboot+vue的在线教育平台课程考试数据库设计、论文、毕设源码、开题报告】

  博主介绍:👉全网个人号和企业号粉丝40W+,每年辅导几千名大学生较好的完成毕业设计,专注计算机软件领域的项目研发,不断的进行新技术的项目实战👈
⭐️热门专栏推荐订阅⭐️ 订阅收藏起来,防止下次找不到

🔎​百套小程序APP项目实战持续更新中~​

🔎​千套JAVA项目实战持续更新中~​

🔎​百套Python实战项目持续更新中~​
有需求的各位可以先收藏起来,还有大家在毕设选题,开题报告有疑惑的都可以找我,给你参考意见,需要开题模板的可以私信留言告诉我

❤️文末获取源码联系❤️        ⚠️一定要先收藏⚠️

4 系统设计

一个成功设计的系统在内容上必定是丰富的,在系统外观或系统功能上必定是对用户友好的。所以为了提升系统的价值,吸引更多的访问者访问系统,以及让来访用户可以花费更多时间停留在系统上,则表明该系统设计得比较专业。

4.1 设计原则

本系统在设计过程中需要依照一定的设计原则进行,目的就是为了让开发的系统具备高质量,齐全完备的功能,方便简单的操作,如此才可以最大限度的满足使用者的要求。系统设计原则除了基本的易操作原则外,还有安全性原则,准确性原则。

第一个设计原则:易操作原则,针对本系统设计的功能要完备齐全,编码时,设计的各个接口要具备友好性,使用者一旦使用本系统时,要能够轻松上手,操作本系统处理数据时,要具备便利性。此外,也需要设计一些必要提示,引导使用者操作系统。

第二个设计原则:安全性原则,本系统在登录模块要对各个访问者进行身份验证,系统会通过访问者输入的信息进行判断,使用提前编写的安全验证代码进行数据比对,引导匹配成功的访问者进入指定的操作界面。这样可以避免无关性访问者窃取系统的数据。

第三个设计原则:准确性原则,为了保证使用者登记的数据是正确的,需要提前设计数据纠错机制,让使用者可以通过系统的报错提示,仔细检查登记的错误信息,并及时纠正错误,填写规范正确的信息。比如设置密码时,要求密码的长度不能低于6个字符,且数据类型要求不能全部是数字等都能进行规范。

4.2 功能结构设计

在前面分析的管理员功能的基础上,进行接下来的设计工作,最终展示设计的管理员结构图(见下图)。管理员增删改查课程信息

4.3 数据库设计

开发一个系统也需要提前设计数据库。这里的数据库是相关数据的集合,存储在一起的这些数据也是按照一定的组织方式进行的。目前,数据库能够服务于多种应用程序,则是源于它存储方式最佳,具备数据冗余率低的优势。虽然数据库为程序提供信息存储服务,但它与程序之间也可以保持较高的独立性。总而言之,数据库经历了很长一段时间的发展,从最初的不为人知,到现在的人尽皆知,其相关技术也越发成熟,同时也拥有着坚实的理论基础。

(1)下图是考试记录表实体和其具备的属性。


考试记录表实体属性图

(2)下图是教师实体和其具备的属性。


教师实体属性图

(3)下图是答题详情表实体和其具备的属性。


答题详情表实体属性图

(4)下图是公告信息实体和其具备的属性。


公告信息实体属性图

(5)下图是操作日志实体和其具备的属性。


操作日志实体属性图

(6)下图是试卷选题实体和其具备的属性。


试卷选题实体属性图

(7)下图是错题表实体和其具备的属性。


错题表实体属性图

(8)下图是课程信息实体和其具备的属性。


课程信息实体属性图

(9)下图是论坛实体和其具备的属性。


论坛实体属性图

(10)下图是试卷表实体和其具备的属性。


试卷表实体属性图

(11)下图是学生实体和其具备的属性。


学生实体属性图

(12)下图是教师咨询实体和其具备的属性。


教师咨询实体属性图

4.3.2 数据库物理设计

本数据库是关系型数据库,因此对二维表的结构设计也比较关键。毕竟二维表格模型就是关系型数据库中的关系模型。而一些常用的关系模型中的概念也需要了解,才可以对关系模型进行设计。下面就简单介绍关系,元组,属性,域,关键字等常用概念的含义。

关系:关系就是数据库中的一张数据表,每张数据表都有命名,也就是每个关系也有名字,那就是数据表名;

元组:元组就是数据表中的一行记录;

属性:属性就是数据表中的字段,也就是数据表中的一列;

域:域就是对数据表中属性的取值进行限定;

关键字:关键字就是数据表中的主键;

在了解了表结构设计的常用概念后,接下来就需要使用前面绘制的E-R模型完成表结构的设计工作,并在数据库中创建数据表,并为各个数据表进行命名。以下就对设计的结果通过表格形式进行展示。

表4.1操作日志表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

caozuorizhi_this_biao

String

操作人所在表

3

caozuorizhi_caozuobiao

String

操作表

4

caozuorizhi_caozuozhanghu

String

操作账户

5

caozuorizhi_caozuoleixing

String

操作类型

6

caozuorizhi_text

String

操作内容

7

insert_time

Date

操作时间

8

create_time

Date

创建时间

表4.2字典表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

dic_code

String

字段

3

dic_name

String

字段名

4

code_index

Integer

编码

5

index_name

String

编码名字

6

super_id

Integer

父字段id

7

beizhu

String

备注

8

create_time

Date

创建时间

表4.3试卷表表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

exampaper_name

String

试卷名称

3

exampaper_date

Integer

考试时长(分钟)

4

exampaper_myscore

Integer

试卷总分数

5

kemu_types

Integer

科目

6

exampaper_types

Integer

试卷状态

7

zujuan_types

Integer

组卷方式

8

exampaper_delete

Integer

逻辑删除(1代表未删除 2代表已删除)

9

create_time

Date

创建时间

表4.4试卷选题表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

exampaper_id

Integer

试卷

3

examquestion_id

Integer

试题

4

exampapertopic_number

Integer

试题分数

5

create_time

Date

创建时间

表4.5试题表表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

examquestion_name

String

试题名称

3

kemu_types

Integer

科目

4

examquestion_options

String

选项,json字符串

5

examquestion_answer

String

正确答案

6

examquestion_analysis

String

答案解析

7

examquestion_types

Integer

试题类型

8

examquestion_sequence

Integer

试题排序,值越大排越前面

9

create_time

Date

创建时间

表4.6考试记录表表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

examrecord_uuid_number

String

考试编号

3

yonghu_id

Integer

考试学生

4

exampaper_id

Integer

所属试卷id(外键)

5

total_score

Integer

所得总分

6

insert_time

Date

考试时间

7

create_time

Date

创建时间

表4.7答题详情表表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

examredetails_uuid_number

String

试卷编号

3

yonghu_id

Integer

学生id

4

examquestion_id

Integer

试题id(外键)

5

examredetails_myanswer

String

考生答案

6

examredetails_myscore

Integer

试题得分

7

create_time

Date

创建时间

表4.8错题表表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

yonghu_id

Integer

学生id

3

exampaper_id

Integer

试卷(外键)

4

examquestion_id

Integer

试题id(外键)

5

examredetails_myanswer

String

考生作答

6

insert_time

Date

记录时间

7

create_time

Date

创建时间

表4.9论坛表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

forum_name

String

帖子课程

3

yonghu_id

Integer

学生

4

users_id

Integer

管理员

5

forum_content

String

发布内容

6

super_ids

Integer

父id

7

forum_state_types

Integer

帖子状态

8

insert_time

Date

发帖时间

9

update_time

Date

修改时间

10

create_time

Date

创建时间

表4.10教师表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

jiaoshi_name

String

教师姓名

3

jiaoshi_photo

String

头像

4

jiaoshi_phone

String

教师手机号

5

jiaoshi_id_number

String

教师身份证号

6

jiaoshi_email

String

邮箱

7

jiaoshi_content

String

教师简介

8

jiaoshi_delete

Integer

假删

9

create_time

Date

创建时间

表4.11教师咨询表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

yonghu_id

Integer

提问人

3

jiaoshi_id

Integer

回答人

4

jiaoshi_chat_issue_text

String

问题

5

issue_time

Date

问题时间

6

jiaoshi_chat_reply_text

String

回复

7

reply_time

Date

回复时间

8

zhuangtai_types

Integer

状态

9

jiaoshi_chat_types

Integer

数据类型

10

insert_time

Date

提问时间

11

create_time

Date

创建时间

表4.12课程信息表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

kecheng_name

String

课程名称

3

kecheng_photo

String

课程照片

4

kecheng_video

String

课程视频

5

kecheng_file

String

课程文件

6

jiaoshi_id

Integer

教师

7

zan_number

Integer

8

cai_number

Integer

9

kecheng_types

Integer

课程类型

10

kecheng_content

String

详情

11

kecheng_delete

Integer

逻辑删除

12

insert_time

Date

录入时间

13

create_time

Date

创建时间

表4.13课程收藏表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

kecheng_id

Integer

课程

3

yonghu_id

Integer

用户

4

kecheng_collection_types

Integer

类型

5

insert_time

Date

收藏时间

6

create_time

Date

创建时间

表4.14公告信息表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

news_name

String

公告课程

3

news_types

Integer

公告类型

4

news_photo

String

公告图片

5

insert_time

Date

添加时间

6

news_content

String

公告详情

7

create_time

Date

创建时间

表4.15单页数据表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

single_seach_name

String

名字

3

single_seach_types

Integer

数据类型

4

single_seach_photo

String

图片

5

single_seach_content

String

内容

6

create_time

Date

创建时间

表4.16学生表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

yonghu_name

String

学生姓名

3

yonghu_photo

String

头像

4

yonghu_phone

String

学生手机号

5

yonghu_id_number

String

学生身份证号

6

yonghu_email

String

邮箱

7

yonghu_delete

Integer

假删

8

create_time

Date

创建时间

表4.17证书获取表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

zhengshuhuoqu_name

String

标题

3

yonghu_id

Integer

用户

4

zhengshuhuoqu_types

Integer

证书类型

5

zhengshuhuoqu_time

Date

获取时间

6

zhengshuhuoqu_content

String

详情

7

zhengshuhuoqu_delete

Integer

逻辑删除

8

insert_time

Date

录入时间

9

create_time

Date

创建时间

表4.18管理员表

序号

列名

数据类型

说明

允许空

1

Id

Int

id

2

username

String

学生名

3

password

String

密码

4

role

String

角色

5

addtime

Date

新增时间


5.1学生信息管理

如图5.1显示的就是学生信息管理页面,此页面提供给管理员的功能有:学生信息的查询管理,可以删除学生信息、修改学生信息、新增学生信息,

还进行了对用户名称的模糊查询的条件

图5.1 学生信息管理页面

5.2 课程信息管理

如图5.2显示的就是课程信息管理页面,此页面提供给管理员的功能有:查看已发布的课程信息数据,修改课程信息,课程信息作废,即可删除,还进行了对课程信息名称的模糊查询 课程信息信息的类型查询等等一些条件。

图5.2 课程信息管理页面

5.3证书获取信息管理

如图5.3显示的就是证书获取信息管理页面,此页面提供给管理员的功能有:根据证书获取信息进行条件查询,还可以对证书获取信息进行新增、修改、查询操作等等。

图5.3 证书获取信息管理页面

JAVA后端代

package com.controller;
 
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;
 
import javax.servlet.http.HttpServletRequest;
 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
 
import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;
 
/**
 * 登录相关
 */
@RequestMapping("users")
@RestController
public class UserController{
	
	@Autowired
	private UserService userService;
	
	@Autowired
	private TokenService tokenService;
 
	/**
	 * 登录
	 */
	@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }
 
	/**
	 * 退出
	 */
	@GetMapping(value = "logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
	
	/**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }
	
	/**
     * 列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,UserEntity user){
        EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
    	PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
        return R.ok().put("data", page);
    }
 
	/**
     * 列表
     */
    @RequestMapping("/list")
    public R list( UserEntity user){
       	EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
      	ew.allEq(MPUtil.allEQMapPre( user, "user")); 
        return R.ok().put("data", userService.selectListView(ew));
    }
 
    /**
     * 信息
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }
    
    /**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        UserEntity user = userService.selectById(id);
        return R.ok().put("data", user);
    }
 
    /**
     * 保存
     */
    @PostMapping("/save")
    public R save(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }
 
    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody UserEntity user){
//        ValidatorUtils.validateEntity(user);
    	UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
    	if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
    		return R.error("用户名已存在。");
    	}
        userService.updateById(user);//全部更新
        return R.ok();
    }
 
    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        userService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
}

源码获取

大家点赞、收藏、关注 ,让更多需要的同学看到

不同开发语言专栏推荐订阅

 🔎​百套小程序APP项目实战持续更新中~​

🔎​千套JAVA项目实战持续更新中~​

🔎​百套Python实战项目持续更新中~​

👇下方有我的微信名片👇

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值