(附源码)springboot公选课在线选课系统 毕业设计 142011
公选课在线选课系统
摘 要
随着互联网趋势的到来,各行各业都在考虑利用互联网将自己推广出去,最好方式就是建立自己的互联网系统,并对其进行维护和管理。在现实运用中,应用软件的工作规则和开发步骤,采用Java技术建设公选课在线选课系统。
本设计主要实现集人性化、高效率、便捷等优点于一身的公选课在线选课系统,完成首页、公共管理(轮播图、公告栏)用户管理(管理员、教师、学生)系统内容(新闻管理、新闻分类)系统模块(专业分类管理、课程管理、学生选课管理、教学任务管理、学院管理、班级管理、成绩管理、通知学生管理、通知教师管理、数据备份)等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。只需通过一台电脑,动动手指就可以操作系统,实现数据通信管理。整个系统的设计过程都充分考虑了数据的安全、稳定及可靠等问题,而且操作过程简单。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。
公选课在线选课系统使用Java语言,采用基于 MVVM模式的Java技术进行开发,使用 MyEclipse 2017 CI 10 编译器编写,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介,配合前台HTML+CSS 技术完成系统的开发。
关键词:数据通信;Java语言;关系型数据库;数据存储
Online course selection system for public courses
Abstract
With the advent of the Internet trend, all walks of life are considering using the Internet to promote themselves. The best way is to establish their own Internet system and maintain and manage it. In practical application, according to the working rules and development steps of the application software, Java technology is used to build the online course selection system of public courses.
This design mainly realizes the online course selection system of public elective courses, which integrates the advantages of humanization, high efficiency and convenience Public Management (rotation chart, bulletin board) user management (administrator, teacher, student) system content (news management, news classification) system module (professional classification management, curriculum management, student course selection management, teaching task management, college management, class management, performance management, student notification management, teacher notification management, data backup) and other functional modules. The system communicates with the server through the browser to realize the interaction and change of data. You can operate the system and realize data communication management by moving your fingers through a computer. The safety, stability and reliability of data are fully considered in the design process of the whole system, and the operation process is simple. Through scientific management and convenient service, the system improves work efficiency and reduces errors and omissions in data storage.
The online course selection system of public elective courses uses Java language and Java technology based on MVVM mode. It is written with MyEclipse 2017 CI 10 compiler. In terms of data, it mainly uses Microsoft's MySQL relational database as the data storage medium, and completes the development of the system with the foreground HTML + CSS technology.
Keywords: data communication; Java language; Relational database; data storage
目 录
第1章 绪论 1
1.1 研究背景 1
1.2 开发意义 1
1.3 开发现状 1
第2章 相关技术介绍 3
2.1 开发技术 3
2.2 MVVM模式 3
2.3 MySQL数据库 3
2.4 B/S结构 4
2.5 Springboot框架介绍 4
2.6 Vue.js 主要功能 5
第3章 系统分析 6
3.1 可行性分析 6
3.1.1 技术可行性分析 6
3.1.2 经济可行性分析 6
3.1.3 操作可行性分析 6
3.1.4 法律条规可行性分析 6
3.2 需求分析 6
3.3 非功能需求分析 8
3.4 业务流程分析 8
3.5 数据流程分析 9
第4章 系统设计 12
4.1 系统结构设计 12
4.2 功能模块设计 12
4.3 数据库设计 14
4.3.1 概念模型设计 14
4.3.2 数据表设计 14
第5章 系统实现 22
5.1 基本任务 22
5.2 主页面 22
5.3 登录模块的实现 23
5.4 课程选课模块 26
5.5 学生成绩模块 28
5.6 学生管理模块 30
5.7 课程管理模块 31
5.8 公告管理模块 33
第6章 系统测试 37
6.1 测试目的 37
6.2 测试概述 37
6.3 单元测试 37
6.3.1 登录功能测试 37
6.3.2 选课功能测试 37
6.3.3 课程功能测试 38
6.4 集成测试 38
第7章 总结 39
致谢 40
参考文献 41
MVC模式是常用的开发模式,主要是在代码实现上将其分为M层、V层和C层。
- MySQL数据库
科技的进步,给日常带来许多便利:教室的投影器用到了虚拟成像技术,数码相机用到了光电检测技术,比如超市货物进出库的记录需要一个信息仓库。这个信息仓库就是数据库,而这次的公选课在线选课系统也需要这项技术的支持[7]。
用MySQL这个软件,是因为它能接受多个使用者访问,而且里面存在Archive等。它会先把数据进行分类,然后分别保存在表里,这样的特别操作就会提高数据管理系统自身的速度,让数据库能被灵活运用。MySQL的代码是公开的,而且允许别人二次编译升级。这个特点能够降低使用者的成本,再搭配合适的软件后形成一个良好的网站系统。虽然它有缺点,但是综合各方面来说,它是使用者的主流运用的对象[8]。
Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。另一方面,Vue 完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复杂单页应用。
Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。
Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能驱动复杂的单页应用。
本次设计基于B/S 模式下,运用Java、JSP技术采用的是MySQL数据库和Myeclipse实现,总体的可行性共分为以下三个方面。
开发软件有没有触犯法律,这涉及到软件或者系统能不能发布的问题。如果触犯了法律,就必将会受到法律的制裁。常见法律问题就是软件抄袭问题,若是抄袭别人软件,将会受到严厉惩罚。
系统非功能需求有非常多,比如性能需求、可承载最大用户数、稳定性、易用性需求等。本系统分析时考虑到易用性需求,因为系统是给人使用的,所以必须充分从用户的角度出发,考虑用户体验,使系统易理解易上手易操作。
经过对系统功能的分析,调查,研究,总结出公选课在线选课系统主要实现的是对选课信息、课程信息等管理功能。这样,可以对该系统绘制业务流程图。
零层数据流程图包括了登录、用户功能和检索维护等模块,在登录模块使用到的数据存储有用户账户文档,用户功能模块需要的存储是用户各功能模块数据文档,检索维护是使用以上这些数据文档通过关键词进行检索。
学生和课程存在选课关系,关系为一对多,根据课程编号来将课程数据传入到选课数据中,操作人为学生,然后生成选课列表,学生查看个人历史选课列表,可以进行数据销毁。
操作人来录入课程数据,点击课程录入按钮,依次填写要录入的课程数据,点击提交按钮,将数据提交至数据库,然后刷新课程数据页面,每条数据右边有删除和编辑按钮,来完成相应的删除和更新功能。
教师和学生存在成绩录入关系,关系为一对多,根据学生编号来将学生数据传入到成绩数据中,操作人为教师,然后生成成绩列表,教师查看个人历史成绩列表,可以进行数据销毁。
操作人来录入学生数据,点击学生录入按钮,依次填写要录入的学生数据,点击提交按钮,将数据提交至数据库,然后刷新学生数据页面,每条数据右边有删除和编辑按钮,来完成相应的删除和更新功能。
管理员点击公告管理菜单,点击公告添加子菜单,添加公告数据,填写标题、内容、类别、图片,提交成功后,公告数据页面刷新,新数据成功载入页面。
数据库逻辑结构就是将E-R图在数据库中用具体的字段进行描述。用字段和数据类型描述来使对象特征实体化,最后形成具有一定逻辑关系的数据库表结构。公选课在线选课系统所需要的部分数据结构表如下表所示。
class_management |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
class_management_id |
int |
11 |
否 |
主键 |
班级管理ID |
class_number |
varchar |
64 |
是 |
班号 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
college_management |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
college_management_id |
int |
11 |
否 |
主键 |
学院管理ID |
college |
varchar |
64 |
是 |
学院 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
course_selection_management |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
course_selection_management_id |
int |
11 |
否 |
主键 |
选课管理ID |
course_number |
varchar |
64 |
是 |
课程编号 |
|
course_name |
varchar |
64 |
是 |
课程名称 |
|
professional_type |
varchar |
64 |
是 |
专业类型 |
|
suitable_grade |
varchar |
64 |
是 |
适学年级 |
|
limited_number_of_people |
varchar |
64 |
是 |
限定人数 |
|
teacher |
int |
11 |
是 |
教师 |
|
student |
int |
11 |
是 |
学生 |
|
student_number |
varchar |
64 |
是 |
学号 |
|
class_number |
varchar |
64 |
是 |
班号 |
|
number_of_people |
varchar |
64 |
是 |
人数 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
curriculum |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
curriculum_id |
int |
11 |
否 |
主键 |
课程ID |
course_number |
varchar |
64 |
否 |
课程编号 |
|
course_name |
varchar |
64 |
是 |
课程名称 |
|
professional_type |
varchar |
64 |
是 |
专业类型 |
|
course_cover |
varchar |
255 |
是 |
课程封面 |
|
suitable_grade |
varchar |
64 |
是 |
适学年级 |
|
teacher |
int |
11 |
是 |
教师 |
|
limited_number_of_people |
int |
11 |
是 |
限定人数 |
|
number_of_people_selected |
int |
11 |
是 |
已选人数 |
|
course_details_ |
longtext |
0 |
是 |
课程详情 |
|
hits |
int |
11 |
否 |
点击数 |
|
praise_len |
int |
11 |
否 |
点赞数 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
limit_times |
int |
8 |
否 |
限制次数 |
|
limit_type |
tinyint |
2 |
否 |
限制次数类型1-每天次,2-总计次 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
data_backup |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
data_backup_id |
int |
11 |
否 |
主键 |
数据备份ID |
backup_time |
date |
0 |
是 |
备份时间 |
|
backup_name |
varchar |
64 |
是 |
备份名称 |
|
backup_files |
varchar |
255 |
是 |
备份文件 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
inform_students |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
inform_students_id |
int |
11 |
否 |
主键 |
通知学生ID |
title |
varchar |
64 |
是 |
标题 |
|
student |
int |
11 |
是 |
学生 |
|
video_file_ |
varchar |
255 |
是 |
视频文件 |
|
enclosure |
varchar |
255 |
是 |
附件 |
|
notice_content |
longtext |
0 |
是 |
通知内容 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
inform_the_teacher |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
inform_the_teacher_id |
int |
11 |
否 |
主键 |
通知教师ID |
title |
varchar |
64 |
是 |
标题 |
|
teacher |
int |
11 |
是 |
教师 |
|
video_file_ |
varchar |
255 |
是 |
视频文件 |
|
enclosure |
varchar |
255 |
是 |
附件 |
|
notice_content |
longtext |
0 |
是 |
通知内容 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
professional_classification |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
professional_classification_id |
int |
11 |
否 |
主键 |
专业分类ID |
professional_type |
varchar |
64 |
是 |
专业类型 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
student |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
student_id |
int |
11 |
否 |
主键 |
学生ID |
student_number |
varchar |
64 |
否 |
学号 |
|
gender |
varchar |
64 |
是 |
性别 |
|
class_number |
varchar |
64 |
是 |
班号 |
|
college |
varchar |
64 |
是 |
学院 |
|
major |
varchar |
64 |
是 |
专业 |
|
examine_state |
varchar |
16 |
否 |
审核状态 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
teacher |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
teacher_id |
int |
11 |
否 |
主键 |
教师ID |
employee_number |
varchar |
64 |
否 |
职工号 |
|
gender |
varchar |
64 |
是 |
性别 |
|
college |
varchar |
64 |
是 |
学院 |
|
examine_state |
varchar |
16 |
否 |
审核状态 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
teaching_task |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
teaching_task_id |
int |
11 |
否 |
主键 |
教学任务ID |
task_name |
varchar |
64 |
是 |
任务名称 |
|
task_time |
date |
0 |
是 |
任务时间 |
|
designated_teacher |
int |
11 |
是 |
指定教师 |
|
enclosure |
varchar |
255 |
是 |
附件 |
|
task_content |
text |
0 |
是 |
任务内容 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
系统呈现出一种简洁大方的首页:界面简约、鳞次栉比,用户能轻车熟路的使用。出于对系统使用群体广泛的顾虑,应有良好性能的后台。
@SpringBootApplication
@EnableJpaRepositories
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args);
}
}
- 登录模块的实现
系统的登录窗口是用户的入口,用户只有在登录成功后才可以进入访问。通过在登录提交表单,后台处理判断是否为合法用户,进行页面跳转,进入系统中去。
登录合法性判断过程:用户输入账号和密码后,系统首先确定输入输入数据合法性,然后在login.jsp页面发送登录请求,调用src下的mainctrl类的dopost方法来验证。
用户登录模块的IPO如下所示:
输入:用户名和密码。
处理:
1)检测用户输入的账号、密码是否正确及在数据库已对应存在。
2)从数据库中提取记录,并储存在本地的session中(timeout默认=30min)。
3)根据用户名,将其显示在系统首页上。
输出:是否成功的信息。
登录流程图如下所示。
图5-1登录流程图
系统登录界面如下所示。
图5-2系统登录界面
用户登录的逻辑代码如下。
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
Map<String, String> map = new HashMap<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.select(map, new HashMap<>()).getResultList();
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map<String, String> groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
String res = String.valueOf(service.runCountSql(sql).getSingleResult());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
tokenService.save(accessToken);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}
}
- 课程选课模块
课程选课过程中,首先使用getmap(id,"xinxi"),通过课程ID得到课程数据,将课程数据赋值给课程选课,调用CommDAO的insert方法将选课数据插入选课表中,最后查看个人历史课程选课记录,可以销毁历史选课数据。
课程选课流程图如下所示。
图5-12课程选课流程图
课程选课界面如图所示。
图5-13课程选课界面
选课管理界面如图所示。
图5-14选课管理界面
选课添加关键代码如下所示。
@RequestMapping("/get_list")
public Map<String, Object> getList(HttpServletRequest request) {
Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
return success(map);
}
- 学生成绩模块
学生成绩录入过程中,首先使用getmap(id,"xinxi"),通过学生ID得到学生数据,将学生数据赋值给学生成绩,调用CommDAO的insert方法将成绩数据插入成绩表中,最后查看个人历史学生成绩记录,可以销毁历史成绩数据。
学生成绩录入流程图如下所示。
图5-12学生成绩录入流程图
学生成绩录入界面如图所示。
图5-13学生成绩录入界面
成绩管理界面如图所示。
图5-14成绩管理界面
成绩添加关键代码如下所示。
@RequestMapping(value = {"/count_group", "/count"})
public Map<String, Object> count(HttpServletRequest request) {
Query count = service.count(service.readQuery(request), service.readConfig(request));
return success(count.getResultList());
}
@RequestMapping(value = "/del")
public Map<String, Object> del(HttpServletRequest request) {
service.delete(service.readQuery(request), service.readConfig(request));
public void delete(Map<String,String> query,Map<String,String> config){
sql.append(toWhereSql(query, "0".equals(config.get(FindConfig.GROUP_BY))));
log.info("[{}] - 删除操作:{}",table,sql);
Query query1 = runCountSql(sql.toString());
@SpringBootApplication
@EnableJpaRepositories
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args);
}
}
- 公告管理模块
删除公告时,选择需要删除的公告进行删除,把主键的uId传到GonggaoController控制器,再调用控制器的deleteGonggao方法,数据经过GonggaoService业务层解析和处理,请求GonggaoMapper持久层调用deleteByPrimaryKey方法操作数据库将公告数据从数据库中删除。
查找公告时,输入需要查找的公告名,调用getData方法获取所有数据并且进行分页,把获取到的所有数据显示到视图上,这时候只需要用脚本方法便能快速查找,不涉及对数据库操作。
公告管理流程图如下所示。
图5-24公告管理流程图
公告添加界面如下图所示。
图5-25公告添加界面
公告查询界面如下图所示。
图5-26公告查询界面
公告信息添加关键代码如下所示。
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
@Transactional
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
public Map<String,Object> readBody(BufferedReader reader){
BufferedReader br = null;
StringBuilder sb = new StringBuilder("");
try{
br = reader;
String str;
while ((str = br.readLine()) != null){
sb.append(str);
}
br.close();
String json = sb.toString();
return JSONObject.parseObject(json, Map.class);
}catch (IOException e){
e.printStackTrace();
}finally{
if (null != br){
try{
br.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
return null;
}
public void insert(Map<String,Object> body){
StringBuffer sql = new StringBuffer("INSERT INTO ");
sql.append("`").append(table).append("`").append(" (");
for (Map.Entry<String,Object> entry:body.entrySet()){
sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
}
sql.deleteCharAt(sql.length()-1);
sql.append(") VALUES (");
for (Map.Entry<String,Object> entry:body.entrySet()){
Object value = entry.getValue();
if (value instanceof String){
sql.append("'").append(entry.getValue()).append("'").append(",");
}else {
sql.append(entry.getValue()).append(",");
}
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
log.info("[{}] - 插入操作:{}",table,sql);
Query query = runCountSql(sql.toString());
query.executeUpdate();
}
在对该系统进行完详细设计和编码之后,就要对公选课在线选课系统的程序进行测试,检测程序是否运行无误,反复进行测试和修改,使之最后成为完整的软件,满足用户的需求,实现预期的功能。
测试性能 |
用户或操作员登录系统 |
||
用例目的 |
测试用户或操作员登录系统时功能是否正常 |
||
前提条件 |
进入用户登录页面或操作员登录页面 |
||
输入条件 |
预期输出 |
实际情况 |
|
各项信息不予填写,直接点击登陆按钮 |
不允许登录,提示填写账号相关信息 |
一致 |
|
填写错误的登录名或密码后点击登录系统 |
提示用户名或密码错误,要求重新填写进行登录 |
一致 |
|
填写与验证码信息不一致的信息 |
系统显示出提示信息,表明验证码错误,要求重新填写 |
一致 |
测试性能 |
用户进行选课课程的操作 |
||
用例目的 |
测试用户进行选课课程操作时,系统的功能是否正常 |
||
前提条件 |
用户进入课程详情页,该课程能够被选课 |
||
输入条件 |
预期输出 |
实际情况 |
|
用户未登录,点击选课按钮 |
跳转至登录页面,提示用户先进性登录 |
一致 |
|
正常的登录用户,点击选课按钮 |
系统弹出提示框,提示用户选课成功,同时该课程的状态更改为已选课状态 |
一致 |
测试性能 |
课程相关信息管理功能 |
||
用例目的 |
测试系统后台操作员对课程相关信息进行管理的功能是否正常 |
||
前提条件 |
登录系统后台进入相关管理页面 |
||
输入条件 |
预期输出 |
实际情况 |
|
普通操作员登录,点击进入课程相关信息管理的页面 |
提示非超级用户,权限不够,无法进入相关页面 |
一致 |
|
超级操作员登入,删除某个已被选课的课程 |
提示该课程删除失败 |
一致 |
|
点击增加课程按钮 |
页面正常跳转 |
一致 |
|
增加课程是,填写已存在的课程编号 |
提示该编号已存在 |
一致 |
本次系统上线成功后,得到了用户的高度认可,但是在功能上和性能上还需做进一步的研究处理,使其有更高的性能和更好的用户体验。
系统在以后的升级过程中,需要解决一系列用户所提出的问题,例如打印过程中如何避免浏览器的兼容性问题,大量用户访问时,如何保持较高的响应速度,在系统今后的升级过程中将着重解决这些安全性问题。
致谢
首先感谢我的指导老师,设计的完成离不开老师的一系列指导。在毕业设计的完成过程中,老师给出了很多中肯的建议,正是由于老师一丝不苟的工作态度,我的设计才能顺利的完成。
最后,感谢在大学生涯中每一位教导我的老师,是你们教给了我丰富的知识,更教会了我遇到问题时,如何去应对并解决。谢谢你们的帮助与支持。
参考文献
[1]徐佩.新时期计算机软件开发技术的应用及发展趋势[J].农家参谋,2019(08):167.
[2]张帅,崔婀娜,魏立波.互联网+健康在线服务平台的设计与实现[J].科技创新与应用,2019(10):91-92.
[3]谷利国,陈存田,张甲瑞.基于B/S模式的人事教育信息管理系统的分析与设计[J].电脑知识与技术,2019,15(10):58-59.
[4]胥新政,强毅.基于JSP的常用金属材料标准检索平台开发设计[J].制造业自动化,2019,41(03):41-43+69.
[5]王祖维,南淮耀,张英.“互联网+”视域下的高校学生公寓管理系统设计与实现——以沈阳师范大学为例[J].现代商贸工业,2019,40(08):187-188.
[6]廖明华,齐攀.学生职业能力测评管理系统的设计与实现[J].广东交通职业技术学院学报,2019,18(01):48-52.
[7]李冬冬,刘华明,毕学慧,王秀友.旧衣申领系统的设计与实现[J].电脑知识与技术,2019,15(08):47-50.
[8]李庆年.“互联网+”视域下的人才招聘管理系统设计与实现[J].国际公关,2019(03):164-165.
[9]刘婷,彭焕峰,邵淑婷.基于云平台的高校监考管理系统[J].电脑知识与技术,2019,15(07):91-92.
[10]赵丙秀.基于百度AI平台的Web人脸注册和登录系统的实现[J].电脑知识与技术,2019,15(07):114-115.
[11]戴昭颖,尹涛.钢铁行业成本预算系统开发应用实践[J].电子技术与软件工程,2019(04):29-30.
[12]曹灿,刘志刚.基于SSH和Layui的工程科学前沿与实践系统[J].工业控制计算机,2019,32(02):91-92+96.
[13]谢路.基于Web的考务管理系统设计与实现[J].福建电脑,2019,35(01):136-137.
[14]张继东.MySQL数据库基于JSP的访问技术[J/OL].电子技术与软件工程,2017,(15):169(2017-08-03).
免费领取本源代码,请关注点赞+私聊
(附源码)springboot公选课在线选课系统 毕业设计 142011相关推荐
- (附源码)springboot优课在线教学系统 毕业设计 081251
基于Java Web的优课在线教学系统的设计与实现 摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也 ...
- 计算机毕业设计(附源码)python中小学在线考试系统
项目运行 环境配置: Pychram社区版+ python3.7.7 + Mysql5.7 + HBuilderX+list pip+Navicat11+Django+nodejs. 项目技术: dj ...
- (附源码)spring boot学业指导系统 毕业设计 030958
基于Springboot的学业指导APP 摘要 建立.加强和完善学业指导工作是高等教育培养优秀毕业生的一项基础保障,也是提高学生专业学习质量和技能的有效机制,高等学校学业指导工作的开展还需要给予高度重 ...
- (附源码)pringboot餐饮点餐系统 毕业设计301749
Springboot餐饮点餐系统的设计与实现 摘要 随着生活质量的日益改善以及生活节奏的日益加快,人们对餐饮需求的质量以及速度也随之发生着变化.为了满足社会需求,餐饮的高质量和快节奏也渐渐使电话订餐和 ...
- (附源码)SSM网络故障报修系统 毕业设计 291146
SSM网络故障报修系统 摘 要 随着互联网大趋势的到来,社会的方方面面,各行各业都在考虑利用互联网作为媒介将自己的信息更及时有效地推广出去,而其中最好的方式就是建立网络管理系统,并对其进行信息管理.由 ...
- (附源码)ssm校园拼车服务系统 毕业设计211633
SSM校园拼车服务系统 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化,电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用.信息时代的到来已成为不可阻挡的时尚潮流,人类发展 ...
- (附源码)spring boot网上购物系统 毕业设计 311236
Springboot网上购物系统的开发 摘 要 随着Internet的使用越来越广泛,在传统的商业模式中,对于日常各类商品,人们习惯于到各种商家店铺购买.然而在快节奏的新时代中,人们不一定能为购买各 ...
- (附源码)spring boot养老服务系统 毕业设计 163115
基于Springboot的养老服务系统 摘 要 随着互联网趋势的到来,各行各业都在考虑利用互联网将自己推广出去,最好方式就是建立自己的互联网系统,并对其进行维护和管理.在现实运用中,应用软件的工作规 ...
- (附源码)ssm介绍信智能实现系统 毕业设计 260930
SSM介绍信智能实现系统 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化,电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用.信息时代的到来已成为不可阻挡的时尚潮流,人类发 ...
- (附源码)springboot高校社团管理系统的开发毕业设计231128
目 录 摘要 1 绪论 1.1 研究背景 1.2 研究意义 1.3论文结构与章节安排 2 高校社团管理系统系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据增加流程 2.2.2 ...
最新文章
- 推荐7个看似简约,实则惊艳的实用软件,建议收藏!
- MIT与FAIR提出「mixup」,利用数据和标签的随机线性插值提高神经网络的健壮性
- node.js 没有转发_如何用Nodejs编写一个定时消息提醒应用?
- 低电压瞬态抑制二极管,有哪些常用的型号?
- apk文件编译到系统文件中的方法(及包含so库的)
- STM32的同步规则模式使用
- java参数注解pam_CAS3.4 关于PAM模块SSL的详细配置
- PHP:车牌照合法性
- chromium浏览器开发系列第四篇:如何调试最新chromium源码
- InnoDB存储引擎:锁
- fckeditor for java_基于java使用FCKeditor
- TIM_SetCompare1(TIM14,625); 但是这个办法对TIM4行不通。TIM4使用TIM_OCInitStructure.TIM_Pulse = dutyCycle;
- 关于“外接硬盘被写了保护的解决方法”
- 第115章 属性关键字 - SqlListDelimiter
- 为省手续费 上淘宝拍“生活费”
- C#开发金蝶K3插件
- Linux如何管理进程
- 9006 - ProxySQL Error: connection is locked to hostgroup 2 but trying to reach hostgroup 1
- Linux shell的简单学习
- asr标注工具_传统ASR全流程【转载】