JavaWeb在线考试系统(简单版)

JavaWeb在线考试系统

作者简介

作者名:编程界明世隐
简介:CSDN博客专家,从事软件开发多年,精通Java、JavaScript,博主也是从零开始一步步把学习成长、深知学习和积累的重要性,喜欢跟广大ADC一起打野升级,欢迎您关注,期待与您一起学习、成长、起飞!

系统界面图

在这里插入图片描述

引言:

最近琢磨着做了一个简单版本的在线考试系统,网上也没有找到可以参考的,就自己倒腾出来的。

难度系数(易入

因为才有比较基础的语法,对Java初学者、基础不是太好的小伙伴来说,也是比较容易上手的
后端:
1.使用Java Servlet 本身就是Java语法,无缝链接,也无效更种配置,web.xml轻松配置一次既可。
2.采用C3P0连接数据库,配置文件、代码、jar包,均已就位,无需二次操作。
3.代码采用Service、Dao分层逻辑,清晰实用,代码简单易懂。
前端:
1.Jsp也是Java语法,无需学习新东西,直接写Java代码。
2.HTML仅仅只需最简单的常用标签的语法,小白也能轻松明白。
3.css只是一点点页面的样式,很容易。
4.JavaScript需要了解基本的语法,学web必备。
5.Jquery是JavaScript的插件库,这里仅仅是用来与后台交互,仅仅会使用 $.post 与后台交互即可。

最重要的,就是通过比较简单、基础的语法,让你了解用Java怎么开发一个web系统,完整的了解整个开发流程,进而提升学习的信心和增加成就感。

开发环境

仅仅是我个人的喜欢用,也可以自己选自己喜欢的
开发工具:eclipse/myEclipse
数据库:mysql
web容器:tomcat
jdk版本:1.6

系统功能

在这里插入图片描述

角色介绍

1.管理员
权限:管理员是权限最大的角色,有系统所有的权限。
在这里插入图片描述

2.老师
权限:学员管理、试题管理、试卷管理、考试记录、密码管理、登陆模块。
在这里插入图片描述

3.学员
权限:试卷管理(考试)、考试记录(查看)、密码管理、登陆模块。
在这里插入图片描述

表结构介绍

用户表

//用户表
CREATE TABLE `user` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `no` varchar(20) default NULL COMMENT '账号-学生一般用学号',
  `name` varchar(100) not NULL COMMENT '名字',
  `password` varchar(20) not NULL COMMENT '密码',
  `sex` varchar(20) default NULL COMMENT '性别',
  `phone` varchar(20) default NULL COMMENT '电话',
  `role_id` int(11) default NULL COMMENT '角色 0管理员,1老师,2学员',
  `isValid` varchar(4) default 'Y' COMMENT '是否有效,Y有效,其他无效',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

默认插入管理员数据

//插入管理的数据
INSERT INTO `user` VALUES ('1', 'admin', '管理员', '123', '1', '111', '0', 'Y');

菜单表

CREATE TABLE `menu` (
  `id` int(11) NOT NULL,
  `menuCode` varchar(8) default NULL COMMENT '菜单编码',
  `menuName` varchar(16) default NULL COMMENT '菜单名字',
  `menuLevel` varchar(2) default NULL COMMENT '菜单级别',
  `menuParentCode` varchar(8) default NULL COMMENT '菜单的父code',
  `menuClick` varchar(16) default NULL COMMENT '点击触发的函数',
  `menuRight` varchar(8) default NULL COMMENT '2表示学员,1表示老师,0管理员,可以用逗号组合使用',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

默认插入的数据(建议一行行的插入,反正我的mysql一条条的弄,不然后面的中文会乱码

INSERT INTO `menu` VALUES ('1', '001', '老师管理', '1', null, 'adminManage', '0');
INSERT INTO `menu` VALUES ('2', '002', '学员管理', '1', null, 'userManage', '0,1');
INSERT INTO `menu` VALUES ('3', '003', '试题管理', '1', null, 'itemManage', '0,1');
INSERT INTO `menu` VALUES ('4', '004', '试卷管理', '1', null, 'examManage', '0,1,2');
INSERT INTO `menu` VALUES ('5', '005', '考试记录', '1', null, 'recordManage', '0,1,2');
INSERT INTO `menu` VALUES ('6', '006', '修改密码', '1', null, 'modPwd', '0,1,2');
INSERT INTO `menu` VALUES ('7', '007', '退出系统', '1', null, 'logout', '0,1,2');

题目表

//题目表
CREATE TABLE `item` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `name` varchar(100) default NULL COMMENT '题名',
  `content` varchar(1000) not NULL COMMENT '内容',
  `type` int(11) not NULL COMMENT '类型:1单选 2多选 3判断 4主观',
  `answer` varchar(1000) default NULL  COMMENT '答案',
  `itemVals` varchar(1000) default NULL  COMMENT '选项',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

试卷表

//试卷表
CREATE TABLE `exam` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `name` varchar(100) default NULL COMMENT '试卷名称',
  `userId` int(11) not NULL COMMENT '创建人',
  `time` int(11) not NULL COMMENT '考试时长',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

试卷试题关系表

//试卷试题关系表
CREATE TABLE `exam_item_rel` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `level` int(11) not NULL COMMENT '属于第几大题',
  `itemId` int(11) not NULL COMMENT '试题ID',
  `examId` int(11) not NULL COMMENT '试卷ID',
  `count` int(11) not NULL COMMENT '分数',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

考试记录表

//考试记录表
CREATE TABLE `record` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `examId` int(11) not NULL COMMENT '试卷id',
  `userId` int(11) not NULL COMMENT '考试人id',
  `starttime` datetime default NULL COMMENT '开始时间',
  `endtime` datetime default NULL COMMENT '结束时间',
  `count` varchar(100) default NULL COMMENT '分数',
  `state` varchar(100) default NULL COMMENT '试卷状态 1考试中,2阅卷中,3已阅卷',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

考试记录关系表

CREATE TABLE `record_rel` (
  `id` int(11) NOT NULL auto_increment COMMENT '主键',
  `recordId` int(11) not NULL COMMENT '记录ID',
  `itemId` int(11) not NULL COMMENT '试题ID',
  `answer` varchar(100) default NULL COMMENT '学生答案',
  `count` int(11) default NULL COMMENT '当前题分数',
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

系统模块介绍

老师管理

管理员才有的权限,可以增加、修改、删除老师。
在这里插入图片描述
在这里插入图片描述

学员管理

老师和管理员均有权限,可以增加、修改、删除。
在这里插入图片描述
在这里插入图片描述

试题管理

老师和管理员均有权限,可以增加、修改、删除、查看。
在这里插入图片描述
在这里插入图片描述

试卷管理

老师和管理员均有权限,可以增加、修改、删除、查看。
学生有考试功能。
在这里插入图片描述

在这里插入图片描述

考试记录

老师和管理员均有权限,可以查看、阅卷(针对主观题)。
学生有查看自己考试的记录功能。
在这里插入图片描述
在这里插入图片描述

注册功能

在这里插入图片描述

修改密码

在这里插入图片描述

代码目录

java文件
在这里插入图片描述
页面
在这里插入图片描述
后端分层
在这里插入图片描述


总结

因为有之前类似系统的积累,所以编码效率比较吧,这也是老程序员的能力,有代码参考 CV 的很快,哈哈!也希望能够给朋友们带来些许帮助!

注意点

1.样式比较简单,可能不太好看,因为没有去花精力做样式。
2.表设计可能不是特别完善、功能也比较简单,自己凭感觉做的。
3.难免会有些bug吧,不过也不是上线用的,参考学习的话我觉得是足够了。
4.代码里面也有部署文档。

代码获取方式

订阅我的专栏《JavaWeb项目实战》后,可以联系博主获取专栏里面的所有文章和1-2份心仪的代码,专栏的文章都是上过csdn热榜的,值得信赖!专栏内目前有[6]篇实例,未来2个月内专栏会更新到15篇以上,一般一周一更,了解一下我的专栏。**

热门专栏推荐

【1】Java小游戏(俄罗斯方块、飞机大战、植物大战僵尸等)
【2】JavaWeb项目实战(图书管理、在线考试、宿舍管理等)
【3】JavaScript精彩实例(飞机大战、贪吃蛇、验证码等)
【4】Java小白入门200例
【5】从零学Java、趣学Java
【6】Idea从零到精通

  • 196
    点赞
  • 1001
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 143
    评论
在用户界面部分,根据需求分析的结果,用户需要一个用户友善界面。在界面设计上,应做到简单明了,易于操作,并且要注意到界面的布局,应突出的显示重要以及出错信息。外观上也要做到合理化,考虑到用户多对网页较熟悉,应尽量向这一方向靠拢。在设计语言上,已决定使用 Java 语言进行编程。 其中管理界面要做到操作简单,易于管理。总的来说,系统的用户界面应作到可靠性、简单性、易学习和使用。 2.4.2 外部接口 硬件接口,在输入方面对于键盘鼠标的输入用标准的输入/输出,对输入进行处理。在输出方面的屏幕和打印机连接以及使用用标准的输入输出进行处理。 2.4.3 内部接口 各模块之间采用函数调用,参数传递,返回值的方式进行信息传递。接口传递的信息将是以数据结构封装了的数据,以参数传递或返回值的形式在各模块间传输 2.5 运行设计 运行程序,执行登录模块,如果是新用户,就进入注册模块,已注册的用户直接进行身份验证进入主界面,通过主界面可以进行在线考试,此时执行考试模块,也可以查询考试成绩、修改个人资料等功能。 2.6 系统数据库设计 数据库是本系统核心和基础。它把本中大量的数据按一定的模型组织起来,提供存储、维护、检索数据的功能,使信息系统可以方便、及时、准确地从数据库中获得所需的信息。 2.6.1 数据库概念设计 开发在线考试系统时,为了灵活地维护系统,设计了后台管理员模块,通过后台管理员模块可以方便地对整个在线考试系统进行维护。这时,必须建立一个数据表用于存储所有的管理员信息。管理员信息实体E-R 图如图6所示。当考生成功登录在线考试系统后,可以根据需要选择考试的科目,考生不同可能选择的考试科目会不同,系统必须提供一些参加考试的课程,供考生选择。这时,在数据库中应该建立一个存储所有参加课程的数据表。考试课程信息实体E-R图如图7所示。 
一、项目简介本课程演示的是一套基于SSM实现的在线考试系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。课程包含:1. 项目源码、项目文档、数据库脚本、软件工具等所有资料2. 带你从零开始部署运行本套系统3. 该项目附带的源码资料可作为毕设使用4. 提供技术答疑二、技术实现后台框架:Spring、SpringMVC、MyBatisUI界面:JSP、jQuery 、BootStrap数据库:MySQL 三、系统功能该在线考试系统基于B/S架构,采用SSM框架,运用JSP网页开发技术,并结合MySQL数据库,搭建一个高效、便捷的网络考试平台。 ​本系统分为前台考试模块和后台管理模块,包含学生、教师和管理员共三个角色,功能如下: 1.前台考试模块 学生注册、学生登陆、考试中心、参加考试、查看考试成绩、查看历史考卷、查看个人信息等功能。 2.后台管理模块 系统后台登陆、学生管理、教师管理、班级管理、年级管理、科目管理、试题管理、添加试题、导入试题、试卷管理、生成试卷、考试安排管理、添加考试计划、查看以往考试信息、考试成绩统计等功能。 教师主要完成试卷管理、试题管理、考试计划管理等一些与考试相关的操作;管理员具有最高权限,可以管理学生、老师、试题、题库、考试等信息,同时也可以与老师一样进行考试相关的操作。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 四、项目截图1)前台首面 2)历史试卷回顾 3)系统后台管理 4)试卷管理 5)试题管理  更多Java毕设项目请关注【毕设系列课程】https://edu.csdn.net/lecturer/2104   

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程界小明哥

请博主喝瓶水,博主持续输出!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值