springboot学校学校运动会信息管理系统毕业设计-附源码
摘 要
科技进步的飞速发展引起人们日常生活的巨大变化,电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流,人类发展的历史正进入一个新时代。在现实运用中,应用软件的工作规则和开发步骤,采用Java技术建设学校运动会信息管理系统。
本设计主要实现集人性化、高效率、便捷等优点于一身的学校运动会信息管理系统,完成首页、站点管理(轮播图、公告栏)用户管理(管理员、普通用户、运动员、裁判员)更多管理(身份申请、运动商品、订单中心、赛事分类、赛事信息、报名信息、选手信息、投票记录、成绩中心)等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。学校运动会信息管理系统使用Java语言,采用基于 MVVM模式的springboot技术进行开发,使用 Eclipse 2017 CI 10 编译器编写,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介,配合前台HTML+CSS 技术完成系统的开发。
关键词:运动会信息管理;Java语言;关系型数据库;数据存储
Springboot school sports meeting information management system
Abstract
The rapid development of scientific and technological progress has caused great changes in people's daily life. The rapid development of electronic information technology has popularized and applied the application level of electronic information technology in various fields. The advent of the information age has become an irresistible fashion trend, and the history of human development is entering a new era. In practical application, according to the working rules and development steps of the application software, Java technology is used to build the school sports meeting information management system.
This design mainly realizes the school sports meeting information management system with the advantages of humanization, high efficiency and convenience, and completes the functional modules such as home page, site management (rotation map, bulletin board), user management (administrator, ordinary users, athletes and referees), more management (identity application, sports goods, order center, event classification, event information, registration information, player information, voting records, achievement Center), etc. The system communicates with the server through the browser to realize the interaction and change of data. Through scientific management and convenient service, the system improves work efficiency and reduces errors and omissions in data storage. The school sports meeting information management system uses Java language, adopts springboot technology based on MVVM mode, and is written with eclipse 2017 CI 10 compiler. In terms of data, Microsoft's MySQL relational database is mainly used as the data storage medium, and the system development is completed with the foreground HTML + CSS technology.
Key words: sports meeting information management; Java language; Relational database; data storage
目 录
第1章 绪论
1.1 研究背景与意义
1.2 开发现状
1.3 本文的组织结构
第2章 相关技术介绍
2.1 开发技术说明
2.2 MVVM模式介绍:
2.3 MySQL数据库
2.4 B/S结构
2.5 spring boot框架介绍:
2.6 Vue.js 主要功能:
第3章 系统分析
3.1 可行性分析
3.1.1 技术可行性分析
3.1.2 经济可行性分析
3.1.3 操作可行性分析
3.2 功能需求分析
3.3 非功能需求分析
3.4 数据流程分析
第4章 系统设计
4.1 系统架构设计
4.2 系统功能结构
4.3 功能模块设计
4.4 数据库设计
4.4.1 概念模型
4.4.2 数据表
第5章 系统实现
5.1 登录模块的实现
5.2 用户子系统模块的实现
5.2.1 用户首页模块
5.2.2 注册模块
5.3 管理员子系统模块的实现
5.3.1 裁判员管理模块
5.3.2 个人资料管理模块
5.3.3 赛事信息模块
5.3.4 运动员成绩管理模块
第6章 系统测试
6.1 测试目的
6.2 软件测试的重要性
6.3 测试实例的研究与选择
6.4 测试环境与测试条件
6.4系统运行情况
6.5系统评价
6.5.1系统功能评价
6.5.2系统技术评价
6.5.3系统经济评价
第7章 总结与展望
参考文献
致谢
第一章是绪论,本文章的开头部分,对本题目的研究背景和研究意义等一些做文字性的描述。
第二章研究了学校运动会信息管理系统的所采用的开发技术和开发工具。
第三章是系统分析部分,包括系统总体需求描述、功能性角度分析系统需求、非功能性等各个方面分析系统是否可以实现。
本系统前端部分基于MVVM模式进行开发,采用B/S模式,后端部分基于Java的springboot框架进行开发。
后端部分:采用springboot作为开发框架,同时集成MyBatis、Redis等相关技术。
Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。
Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能驱动复杂的单页应用。
本次设计基于B/S 模式下,运用Java技术采用的是MySQL数据库和Eclipse实现,总体的可行性共分为以下三个方面。
系统非功能需求有非常多,比如性能需求、可承载最大用户数、稳定性、易用性需求等。本系统分析时考虑到易用性需求,因为系统是给人使用的,所以必须充分从用户的角度出发,考虑用户体验,使系统易理解易上手易操作。
一层数据流程图包括了登录注册、用户功能和检索维护等模块,在登录注册模块使用到的数据存储有用户账户文档,用户功能模块需要的存储是用户各功能模块数据文档,检索维护是使用以上这些数据文档通过关键词进行检索。
数据库逻辑结构就是将E-R图在数据库中用具体的字段进行描述。用字段和数据类型描述来使对象特征实体化,最后形成具有一定逻辑关系的数据库表结构。学校运动会信息管理系统所需要的部分数据结构表如下表所示。
achievement_center |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
achievement_center_id |
int |
11 |
否 |
主键 |
成绩中心ID |
event_name |
varchar |
64 |
是 |
赛事名称 |
|
venue |
varchar |
64 |
是 |
赛事地点 |
|
event_time |
datetime |
0 |
是 |
赛事时间 |
|
head_portrait |
varchar |
255 |
是 |
头像 |
|
athlete_number |
int |
11 |
是 |
运动员编号 |
|
athlete_name |
varchar |
64 |
是 |
运动员姓名 |
|
event_results |
int |
11 |
是 |
赛事成绩 |
|
referee_number |
int |
11 |
是 |
裁判员编号 |
|
name_of_referee |
varchar |
64 |
是 |
裁判员姓名 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
athletes |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
athletes_id |
int |
11 |
否 |
主键 |
运动员ID |
athlete_number |
varchar |
64 |
是 |
运动员编号 |
|
athlete_name |
varchar |
64 |
是 |
运动员姓名 |
|
gender |
varchar |
64 |
是 |
性别 |
|
age |
varchar |
64 |
是 |
年龄 |
|
examine_state |
varchar |
16 |
否 |
审核状态 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
event_classification |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
event_classification_id |
int |
11 |
否 |
主键 |
赛事分类ID |
event_name |
varchar |
64 |
否 |
赛事名称 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
event_information |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
event_information_id |
int |
11 |
否 |
主键 |
赛事信息ID |
event_name |
varchar |
64 |
是 |
赛事名称 |
|
venue |
varchar |
64 |
是 |
赛事地点 |
|
event_time |
datetime |
0 |
是 |
赛事时间 |
|
event_cover |
varchar |
255 |
是 |
赛事封面 |
|
referee_number |
int |
11 |
是 |
裁判员编号 |
|
name_of_referee |
varchar |
64 |
是 |
裁判员姓名 |
|
registration_conditions |
text |
0 |
是 |
报名条件 |
|
event_details |
text |
0 |
是 |
赛事详情 |
|
hits |
int |
11 |
否 |
点击数 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
event_results |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
event_results_id |
int |
11 |
否 |
主键 |
赛事结果ID |
event_name |
varchar |
64 |
是 |
赛事名称 |
|
venue |
varchar |
64 |
是 |
赛事地点 |
|
event_time |
datetime |
0 |
是 |
赛事时间 |
|
selection |
varchar |
64 |
是 |
评选 |
|
head_portrait |
varchar |
255 |
是 |
头像 |
|
athlete_number |
int |
11 |
是 |
运动员编号 |
|
athlete_name |
varchar |
64 |
是 |
运动员姓名 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
identity_application |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
identity_application_id |
int |
11 |
否 |
主键 |
身份申请ID |
apply_for_identity |
varchar |
64 |
是 |
申请身份 |
|
applicant |
int |
11 |
是 |
申请人 |
|
approval_status |
varchar |
64 |
是 |
审批状态 |
|
reason_for_application |
text |
0 |
是 |
申请原因 |
|
review_reply |
text |
0 |
是 |
审核回复 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
order_center |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
order_center_id |
int |
11 |
否 |
主键 |
订单中心ID |
order_number |
varchar |
64 |
是 |
订单号 |
|
commodity_number |
varchar |
64 |
是 |
商品编号 |
|
trade_name |
varchar |
64 |
是 |
商品名称 |
|
commodity_price |
varchar |
64 |
是 |
商品价格 |
|
purchase_quantity |
varchar |
64 |
是 |
购买数量 |
|
total_price |
varchar |
64 |
是 |
总价格 |
|
user_number |
int |
11 |
是 |
用户编号 |
|
user_name |
varchar |
64 |
是 |
用户姓名 |
|
pay_state |
varchar |
16 |
否 |
支付状态 |
|
pay_type |
varchar |
16 |
是 |
支付类型: 微信、支付宝、网银 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
ordinary_users |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
ordinary_users_id |
int |
11 |
否 |
主键 |
普通用户ID |
user_number |
varchar |
64 |
是 |
用户编号 |
|
user_name |
varchar |
64 |
是 |
用户姓名 |
|
gender |
varchar |
64 |
是 |
性别 |
|
age |
varchar |
64 |
是 |
年龄 |
|
examine_state |
varchar |
16 |
否 |
审核状态 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
player_information |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
player_information_id |
int |
11 |
否 |
主键 |
选手信息ID |
event_name |
varchar |
64 |
是 |
赛事名称 |
|
venue |
varchar |
64 |
是 |
赛事地点 |
|
event_time |
datetime |
0 |
是 |
赛事时间 |
|
number_of_votes |
int |
11 |
是 |
拥有票数 |
|
head_portrait |
varchar |
255 |
是 |
头像 |
|
athlete_number |
int |
11 |
是 |
运动员编号 |
|
athlete_name |
varchar |
64 |
是 |
运动员姓名 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
limit_times |
int |
8 |
否 |
限制次数 |
|
limit_type |
tinyint |
2 |
否 |
限制次数类型1-每天次,2-总计次 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
referee |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
referee_id |
int |
11 |
否 |
主键 |
裁判员ID |
referee_number |
varchar |
64 |
是 |
裁判员编号 |
|
name_of_referee |
varchar |
64 |
是 |
裁判员姓名 |
|
gender |
varchar |
64 |
是 |
性别 |
|
age |
varchar |
64 |
是 |
年龄 |
|
examine_state |
varchar |
16 |
否 |
审核状态 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
registration_information |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
sports_goods_id |
int |
11 |
否 |
主键 |
运动商品ID |
commodity_number |
varchar |
64 |
是 |
商品编号 |
|
trade_name |
varchar |
64 |
是 |
商品名称 |
|
commodity_price |
varchar |
64 |
是 |
商品价格 |
|
merchandise_inventory |
int |
11 |
是 |
商品库存 |
|
product_picture |
varchar |
255 |
是 |
商品图片 |
|
product_details |
longtext |
0 |
是 |
商品详情 |
|
hits |
int |
11 |
否 |
点击数 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
|
voting_records |
|||||
字段名称 |
类型 |
长度 |
不是null |
主键 |
字段说明 |
voting_records_id |
int |
11 |
否 |
主键 |
投票记录ID |
event_name |
varchar |
64 |
是 |
赛事名称 |
|
venue |
varchar |
64 |
是 |
赛事地点 |
|
number_of_votes |
varchar |
64 |
是 |
投票数 |
|
athlete_number |
int |
11 |
是 |
运动员编号 |
|
athlete_name |
varchar |
64 |
是 |
运动员姓名 |
|
user_number |
int |
11 |
是 |
用户编号 |
|
user_name |
varchar |
64 |
是 |
用户姓名 |
|
recommend |
int |
11 |
否 |
智能推荐 |
|
user_id |
int |
11 |
否 |
用户ID |
|
create_time |
datetime |
0 |
否 |
创建时间 |
|
update_time |
timestamp |
0 |
否 |
更新时间 |
系统的登录窗口是用户的入口,用户只有在登录成功后才可以进入访问。通过在登录提交表单,后台处理判断是否为合法用户,进行页面跳转,进入系统中去。
登录合法性判断过程:用户输入账号和密码后,系统首先确定输入输入数据合法性,然后在login.jsp页面发送登录请求,调用src下的mainctrl类的dopost方法来验证。
2)从数据库中提取记录,并储存在本地的session中(timeout默认=30min)。
/**
* 登录
* @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, "账号或密码不正确");
}
}
系统呈现出一种简洁大方的首页:界面简约、鳞次栉比,用户能轻车熟路的使用。出于对系统使用群体广泛的顾虑,应有良好性能的后台。
@SpringBootApplication
@EnableJpaRepositories
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class,args);
}
}
此页面实现运动员的注册,必须注册登录后才能使用系统大部分功能,用户名不允许重复如果重复将会注册失败,并弹出相应的提示,通过js实现对输入的验证。
/**
* 注册
* @param user
* @return
*/
@PostMapping("register")
public Map<String, Object> signUp(@RequestBody User user) {
// 查询用户
Map<String, String> query = new HashMap<>();
query.put("username",user.getUsername());
List list = service.select(query, new HashMap<>()).getResultList();
if (list.size()>0){
return error(30000, "用户已存在");
}
user.setUserId(null);
user.setPassword(service.encryption(user.getPassword()));
service.save(user);
return success(1);
}
/**
* 用户ID:[0,8388607]用户获取其他与用户相关的数据
*/
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "user_id")
private Integer userId;
/**
* 账户状态:[0,10](1可用|2异常|3已冻结|4已注销)
*/
@Basic
@Column(name = "state")
private Integer state;
/**
* 所在用户组:[0,32767]决定用户身份和权限
*/
@Basic
@Column(name = "user_group")
private String userGroup;
/**
* 上次登录时间:
*/
@Basic
@Column(name = "login_time")
private Timestamp loginTime;
/**
* 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时
*/
@Basic
@Column(name = "phone")
private String phone;
/**
* 手机认证:[0,1](0未认证|1审核中|2已认证)
*/
@Basic
@Column(name = "phone_state")
private Integer phoneState;
/**
* 用户名:[0,16]用户登录时所用的账户名称
*/
@Basic
@Column(name = "username")
private String username;
/**
* 昵称:[0,16]
*/
@Basic
@Column(name = "nickname")
private String nickname;
/**
* 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成
*/
@Basic
@Column(name = "password")
private String password;
/**
* 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时
*/
@Basic
@Column(name = "email")
private String email;
/**
* 邮箱认证:[0,1](0未认证|1审核中|2已认证)
*/
@Basic
@Column(name = "email_state")
private Integer emailState;
/**
* 头像地址:[0,255]
*/
@Basic
@Column(name = "avatar")
private String avatar;
/**
* 创建时间:
*/
@Basic
@Column(name = "create_time")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Timestamp createTime;
@Basic
@Transient
private String code;
}
@RequestMapping("/get_obj")
public Map<String, Object> obj(HttpServletRequest request) {
Query select = service.select(service.readQuery(request), service.readConfig(request));
List resultList = select.getResultList();
if (resultList.size() > 0) {
JSONObject jsonObject = new JSONObject();
jsonObject.put("obj",resultList.get(0));
return success(jsonObject);
} else {
return success(null);
}
}
public Query select(Map<String,String> query,Map<String,String> config){
StringBuffer sql = new StringBuffer("select ");
sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
}
if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
}
if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
}
log.info("[{}] - 查询操作,sql: {}",table,sql);
return runEntitySql(sql.toString());
}
/**
* 修改密码
* @param data
* @param request
* @return
*/
@PostMapping("change_password")
public Map<String, Object> change_password(@RequestBody Map<String, String> data, HttpServletRequest request){
// 根据Token获取UserId
String token = request.getHeader("x-auth-token");
Integer userId = tokenGetUserId(token);
// 根据UserId和旧密码获取用户
Map<String, String> query = new HashMap<>();
String o_password = data.get("o_password");
query.put("user_id" ,String.valueOf(userId));
query.put("password" ,service.encryption(o_password));
Query ret = service.count(query, service.readConfig(request));
List list = ret.getResultList();
Object s = list.get(0);
int count = Integer.parseInt(list.get(0).toString());
if(count > 0){
// 修改密码
Map<String,Object> form = new HashMap<>();
form.put("password",service.encryption(data.get("password")));
service.update(query,service.readConfig(request),form);
return success(1);
}
return error(10000,"密码修改失败!");
}
@PostMapping("/upload")
public Map<String, Object> upload(@RequestParam("file") MultipartFile file) {
log.info("进入方法");
if (file.isEmpty()) {
return error(30000, "没有选择文件");
}
try {
//判断有没路径,没有则创建
String filePath = System.getProperty("user.dir") + "\\target\\classes\\static\\upload\\";
File targetDir = new File(filePath);
if (!targetDir.exists() && !targetDir.isDirectory()) {
if (targetDir.mkdirs()) {
log.info("创建目录成功");
} else {
log.error("创建目录失败");
}
}
String fileName = file.getOriginalFilename();
File dest = new File(filePath + fileName);
log.info("文件路径:{}", dest.getPath());
log.info("文件名:{}", dest.getName());
file.transferTo(dest);
JSONObject jsonObject = new JSONObject();
jsonObject.put("url", "/api/upload/" + fileName);
return success(jsonObject);
} catch (IOException e) {
log.info("上传失败:{}", e.getMessage());
}
return error(30000, "上传失败");
}
查找运动员成绩时,输入需要查找的运动员成绩名,调用getData方法获取所有数据并且进行分页,把获取到的所有数据显示到视图上,这时候只需要用脚本方法便能快速查找,不涉及对数据库操作。
@RequestMapping(value = "/del")
@Transactional
public Map<String, Object> del(HttpServletRequest request) {
service.delete(service.readQuery(request), service.readConfig(request));
return success(1);
}
@Transactional
public void delete(Map<String,String> query,Map<String,String> config){
StringBuffer sql = new StringBuffer("DELETE FROM ").append("`").append(table).append("`").append(" ");
sql.append(toWhereSql(query, "0".equals(config.get(FindConfig.GROUP_BY))));
log.info("[{}] - 删除操作:{}",table,sql);
Query query1 = runCountSql(sql.toString());
query1.executeUpdate();
}
测试存在于软件开发进程中的最后一个阶段,它可以保证一个软件的开发质量是否符合设计者的初衷,也为程序的正式上线做了最后一道质量检测的工序。软件测试主要是控制各种条件、包括软件输出方式,使用模式和运行环境等,来评估一个系统或应用是否符合设计标准。在软件测试过程中,我们一般刻意的去制造错误和极端条件,不能仅依照正常模式允许,而是多去尝试那些意外的情况。
只有在运行和维护阶段之前经历大量的测试的软件,才能说明它的质量是经得起检验的。最近计算机业界也都一致认为,测试应该存在于软件设计的每个阶段,因为越早发现错误,修复起来就越容易。
黑盒测试,也称为功能测试。它将需软件看作一个黑盒,像一个普通用户一样来模拟软件的使用流程。黑盒测试通过大量的输入边界值或错误数据,来检查是否可产生正确的输出。
本系统测试 主要选择黑盒测试,少量采用白盒测试。通过测试达到以下测试目的:
1.检查各大功能模块的运行,确保其能够正确运行,并检查各页面的完整性,保证页面完整。
2.检查各个接口是否可以正确地输入和输出,保证数据流通稳定可行。
登录部分测试用例 |
|||||
编号 |
对象 |
项目 |
操作 |
预期结果 |
结果 |
1 |
登录 |
登录提示 |
使用正确的账号密码登录 |
成功登录 |
预期结果 |
2 |
登录提示 |
使用正确的账号但错误的密码登录 |
提示密码错误 |
预期结果 |
|
3 |
登录提示 |
使用错误的账号登录 |
提示不存在账户 |
预期结果 |
|
4 |
登录提示 |
不输入账号,点击登录 |
提示输入账号 |
预期结果 |
|
5 |
登录提示 |
输入账号但不输入密码点击登录 |
提示输入密码 |
预期结果 |
|
6 |
登录入口 |
已登录账号,查看登录入口 |
不显示登录入口 |
预期结果 |
全部测试用例都已通过(包括但不限于以上测试用例),且不存在漏洞,实现了论文开始时所作要求。本系统运行稳定,使用流畅,可以满足用户需求。
6.5系统评价
6.5.1系统功能评价
试运行后进行系统评估,可以认为该系统达到预定的目标要求,可以满足用户的需求,也满足了系统开发前所作目标。
6.5.2系统技术评价
系统在经过大量重复测试后运行十分稳定,安全实用,功能模块已经达到预定目标所需。
6.5.3系统经济评价
在规定的时间内实现系统的大部分功能,且满足要求,节省开发成本,有助于提高科学管理水平,符合本人经济情况。
本次系统上线成功后,得到了用户的高度认可,但是在功能上和性能上还需做进一步的研究处理,使其有更高的性能和更好的用户体验。
系统在以后的升级过程中,需要解决一系列用户所提出的问题,例如打印过程中如何避免浏览器的兼容性问题,大量用户访问时,如何保持较高的响应速度,在系统今后的升级过程中将着重解决这些安全性问题。
参考文献
[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学校学校运动会信息管理系统毕业设计-附源码相关推荐
- Springboot+高考志愿填报信息管理系统 毕业设计-附源码251922
Springboot高考志愿填报信息管理系统 摘 要 高中教育的普及使得每年高考人数攀升,与此同时,信息不对称会使部分考生处于劣势,造成获录学校或专业性价比不高.报录比偏低.复读率增高.考研热等问题. ...
- Springboot高考志愿填报信息管理系统毕业设计-附源码
摘 要 高中教育的普及使得每年高考人数攀升,与此同时,信息不对称会使部分考生处于劣势,造成获录学校或专业性价比不高.报录比偏低.复读率增高.考研热等问题.针对这些情况,本文设计并实现了高考志愿填报信息 ...
- pringboot+高考志愿填报信息管理系统 毕业设计-附源码251922S
Springboot高考志愿填报信息管理系统 摘 要 高中教育的普及使得每年高考人数攀升,与此同时,信息不对称会使部分考生处于劣势,造成获录学校或专业性价比不高.报录比偏低.复读率增高.考研热等问题. ...
- springboot+党员信息管理系统 毕业设计-附源码161528
基于Springboot的党员信息管理系统 摘 要 由于数据库和数据仓库技术的快速发展,学校党员信息系统建设越来越向模块化.智能化.自我服务和管理科学化的方向发展.党员信息管理系统除了具有共享系统的全 ...
- springboot+人事信息管理系统 毕业设计-附源码221507
Springboot人事信息管理系统 摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以 ...
- Springboot人事信息管理系统毕业设计-附源码221507
摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题.针对人事信息管理系统等问题 ...
- 小程序Springboot基层慢性病信息管理系统毕业设计-附源码221550
摘 要 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势:对于基层慢性病信息管理系统平台当然也不能排除在外,随着网络技术的不断成熟,带动了基层慢性病信息管理系统小 ...
- springboot+基层慢性病信息管理系统 毕业设计-附源码221550
小程序Springboot基层慢性病信息管理系统 摘 要 随着科学技术的飞速发展,各行各业都在努力与现代先进技术接轨,通过科技手段提高自身的优势:对于基层慢性病信息管理系统平台当然也不能排除在外,随着 ...
- springboot+mysql+基于java的员工信息管理系统 毕业设计-附源码201524
Springboot员工信息管理系统 摘 要 由于数据库和数据仓库技术的快速发展,企业员工信管理建设越来越向模块化.智能化.自我服务和管理科学化的方向发展.员工信息管理对处理对象和服务对象,自身的系统 ...
最新文章
- 单个神经元在深度网络中的作用
- 英特尔网站推广瞄准智慧社区建设,有望加速社区智慧化转型发展
- [一] 详细讲解: 线性表链式存储结构 中的 单链表; (数据结构和算法)
- vb Select Case的使用 字符串整形的转换 输入错误str的直接输出
- A. Slackline Adventure(思维 + 莫比乌斯)(2018-2019 ACM-ICPC Brazil Subregional Programming Contest)
- P4062 [Code+#1]Yazid 的新生舞会(线段树做法)
- vs code 插件_[VSCode插件开发] 由浅入深,带你了解如何打造百万级产品
- 基于模型的系统工程设计软件ModelCoder在航空发动机控制设计中的应用
- C进阶指南(1):整型溢出和类型提升、内存申请和管理(转)
- arch 还原pacman_如何使用Pacman在Arch Linux中安装Go
- python设计模式14-命令模式
- 如何在 Gitee 上使用 GPG
- redmi airdots左右耳不串联怎么办_小米Redmi AirDots蓝牙耳机只能单边连接不能串联的解决办法...
- 统计学习导论(ISLR)第五章bootstrap和交叉验证课后习题
- vb.net 实现编辑某列并回车后不换行,查询数据进行相关处理
- 有没有好的公文写作范文素材,求助各位网友?
- cookie详解,即什么是cookie。
- 小程序自定义日期组件,不显示今日之后的日期
- Ceph RBD 入门系列(一) : 块设备的基本使用及librbd在各个应用场景的位置
- 使用自定义字体升级您的 SwiftUI 应用程序教程,如何在 SwiftUI 中添加自定义字体
热门文章
- java编写旋转风车_用JavaFX几个简单动画——旋转风车、运动的圆
- 不愧是阿里巴巴公布Java10W字面经,在Github标星32K
- 科普丨机械学习与学习机器论述(经典论文)
- 无线通信中的TD系统(TD-LTE)
- 牛客小白月赛2 E.是是非非
- 我电脑感染了一种奇怪的病毒,它点中了我的笑穴!
- 【计算机网络】TCP为什么需要4次挥手
- nacos项目启动报错:Connection refused: no further information
- 【长按图片保存到相册】Vue移动端H5页面实现长按图片保存到手机功能
- 基本电路概念(二)什么是电容?