文末获取源码
开发语言:Java
框架:SSM
技术:Jsp
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql 5.7/8.0
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven3.3.9
浏览器:谷歌浏览器
一、前言介绍
在国外很多发达国家,软件产业早已得到全面普及,但我国经济已不断发展,不断引进国外信息化建设,使国内软件行业得以不断发展,在摸索中进步,最终也得到一些成果,我国的软件业迎来了高速的发展,使更多的软件系统得以开发出来,从此逐渐地改变人们的生活工作方式。但是,对于信息化的建设,与很多发达国家相比,由于信息化程度的落后以及经费的不足,我国的大学运动场地管理系统开发方面还是相对落后的,因此,要不断的努力探索,争取开发出一个实用的信息化的大学运动场地管理系统,来实现行大学运动场地管理的信息化。因此本课题以大学运动场地为例,目的是开发一个实用的大学运动场地管理系统。
大学运动场地管理系统的开发运用jsp技术,MIS的总体思想,以及MYSQL等技术的支持下共同完成了该系统的开发,实现了大学运动场地管理的信息化,使用户体验到更优秀的大学运动场地管理系统,管理员管理操作将更加方便,实现目标。
二、系统功能分析
考虑到实际生活中大学运动场地管理系统方面的需要以及对该平台认真的分析,将系统权限按管理员和用户这两类涉及用户划分。
(a) 管理员;管理员使用本系统涉到的功能主要有主页、个人中心、用户管理、场地信息管理、场地预约管理、器材信息管理、器材借用管理、系统简介管理、器材分类管理、系统管理等功能。管理员用例图如图
(b) 用户;进入系统可以实现首页、场地信息、器材信息、系统简介、新闻通知、个人中心、后台管理等功能。用户用例图如图
系统整功能如下图
三、系统展示
大学运动场地管理系统,在平台首页可以查看首页、场地信息、器材信息、系统简介、新闻通知、个人中心、后台管理等内容,并进行详细操作;如图
用户注册
在用户注册页面通过填写账号、密码、再次输入密码、姓名、手机、住址等信息进行注册操作,如图
场地信息
在场地信息页面可以查看场地名称、场地类型、场地位置、图片、场地状态、开放时间、点击次数、场地详情等内容,并进行预约,评论和收藏等操作,如图
器材信息
在器材信息页面可以查看器材名称、器材类型、规格、图片、器材数量、用途、点击次数、注意事项等内容,并进行借用,评论和收藏等操作,如图
系统简介
在系统简介页面可以查看标题、简介、图片、日期、内容等内容,如图
个人中心
在个人中心页面通过填写账号、密码、姓名、性别、手机、住址、上传图片等内容进行更新信息,还可以根据需要对我的收藏进行相对应操作,如图
管理员功能模块
管理员进行登录,进入系统前在登录页面根据要求填写用户名和密码,选择角色等信息,点击登录进行登录操作,如图
管理员登录系统后,可以对主页、个人中心、用户管理、场地信息管理、场地预约管理、器材信息管理、器材借用管理、系统简介管理、器材分类管理、系统管理等功能进行相应的操作管理,如图
用户管理
在用户管理页面可以对账号、姓名、性别、手机、住址、头像等内容进行查看,修改和删除等操作,如图
场地信息管理
在场地信息管理页面可以对场地名称、场地类型、场地位置、场地状态、开放时间、场地图片等信息进行查看,修改,查看评论和删除操作,如图
场地预约管理
在场地预约管理页面可以对场地名称、场地类型、场地位置、预约时间、备注、账号、姓名、是否审核、审核回复等内容进行审核,查看或删除操作,如图
器材信息管理
在器材信息管理页面可以对器材名称、器材类型、规格、器材数量、用途、器材图片等内容进行查看,修改,查看评论和删除操作,如图
器材借用管理
在器材借用管理页面可以对器材名称、器材类型、规格、器材数量、借用时间、备注、账号、姓名、是否审核、审核回复等内容进行审核,查看或删除操作,如图
系统简介管理
在系统简介管理页面可以对标题、简介、日期、封面等内容进行查看,修改和删除操作,如图
器材分类管理
在器材分类管理页面可以对类型信息进行修改和删除操作,如图
系统管理
在新闻通知管理页面可以对标题、简介、图片等内容进行查看,修改和删除等操作,还可以对轮播图管理进行详细的操作管理;如图
用户后台功能模块
用户登录进入大学运动场地管理系统后台可以对主页、个人中心、场地预约管理、器材借用管理等功能进行相应操作,如图 个人中心
在个人中心页面通过填写账号、姓名、性别、手机、住址、头像等内容并提交进行个人信息修改操作,如图
四、部分核心代码
用户注册
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16/** * 注册 */ @IgnoreAuth @RequestMapping("/register") public R register(@RequestBody YonghuEntity yonghu){ //ValidatorUtils.validateEntity(yonghu); YonghuEntity user = yonghuService.selectOne(new EntityWrapper<YonghuEntity>().eq("zhanghao", yonghu.getZhanghao())); if(user!=null) { return R.error("注册用户已存在"); } Long uId = new Date().getTime(); yonghu.setId(uId); yonghuService.insert(yonghu); return R.ok(); }
上传文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31/** * 上传文件 */ @RequestMapping("/upload") public R upload(@RequestParam("file") MultipartFile file, String type,HttpServletRequest request) throws Exception { if (file.isEmpty()) { throw new EIException("上传文件不能为空"); } String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1); String fileName = new Date().getTime()+"."+fileExt; File dest = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+fileName); file.transferTo(dest); /** * 如果使用idea或者eclipse重启项目,发现之前上传的图片或者文件丢失,将下面一行代码注释打开 * 请将以下的"D:\ssmpiv99\src\main\webapp\upload"替换成你本地项目的upload路径, * 并且项目路径不能存在中文、空格等特殊字符 */ //FileUtils.copyFile(dest, new File("D:\ssmpiv99\src\main\webapp\upload"+"/"+fileName)); /**修改了路径以后请将该行最前面的//注释去掉**/ if(StringUtils.isNotBlank(type) && type.equals("1")) { ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile")); if(configEntity==null) { configEntity = new ConfigEntity(); configEntity.setName("faceFile"); configEntity.setValue(fileName); } else { configEntity.setValue(fileName); } configService.insertOrUpdate(configEntity); } return R.ok().put("file", fileName); }
场地预约
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190/** * 场地预约 * 后端接口 * @author * @email * @date 2022-03-08 09:03:12 */ @RestController @RequestMapping("/changdiyuyue") public class ChangdiyuyueController { @Autowired private ChangdiyuyueService changdiyuyueService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,ChangdiyuyueEntity changdiyuyue, HttpServletRequest request){ String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("yonghu")) { changdiyuyue.setZhanghao((String)request.getSession().getAttribute("username")); } EntityWrapper<ChangdiyuyueEntity> ew = new EntityWrapper<ChangdiyuyueEntity>(); PageUtils page = changdiyuyueService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, changdiyuyue), params), params)); request.setAttribute("data", page); return R.ok().put("data", page); } /** * 前端列表 */ @IgnoreAuth @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,ChangdiyuyueEntity changdiyuyue, HttpServletRequest request){ EntityWrapper<ChangdiyuyueEntity> ew = new EntityWrapper<ChangdiyuyueEntity>(); PageUtils page = changdiyuyueService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, changdiyuyue), params), params)); request.setAttribute("data", page); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( ChangdiyuyueEntity changdiyuyue){ EntityWrapper<ChangdiyuyueEntity> ew = new EntityWrapper<ChangdiyuyueEntity>(); ew.allEq(MPUtil.allEQMapPre( changdiyuyue, "changdiyuyue")); return R.ok().put("data", changdiyuyueService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(ChangdiyuyueEntity changdiyuyue){ EntityWrapper< ChangdiyuyueEntity> ew = new EntityWrapper< ChangdiyuyueEntity>(); ew.allEq(MPUtil.allEQMapPre( changdiyuyue, "changdiyuyue")); ChangdiyuyueView changdiyuyueView = changdiyuyueService.selectView(ew); return R.ok("查询场地预约成功").put("data", changdiyuyueView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") Long id){ ChangdiyuyueEntity changdiyuyue = changdiyuyueService.selectById(id); return R.ok().put("data", changdiyuyue); } /** * 前端详情 */ @IgnoreAuth @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") Long id){ ChangdiyuyueEntity changdiyuyue = changdiyuyueService.selectById(id); return R.ok().put("data", changdiyuyue); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody ChangdiyuyueEntity changdiyuyue, HttpServletRequest request){ changdiyuyue.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(changdiyuyue); changdiyuyueService.insert(changdiyuyue); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody ChangdiyuyueEntity changdiyuyue, HttpServletRequest request){ changdiyuyue.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(changdiyuyue); changdiyuyueService.insert(changdiyuyue); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody ChangdiyuyueEntity changdiyuyue, HttpServletRequest request){ //ValidatorUtils.validateEntity(changdiyuyue); changdiyuyueService.updateById(changdiyuyue);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ changdiyuyueService.deleteBatchIds(Arrays.asList(ids)); return R.ok(); } /** * 提醒接口 */ @RequestMapping("/remind/{columnName}/{type}") public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) { map.put("column", columnName); map.put("type", type); if(type.equals("2")) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar c = Calendar.getInstance(); Date remindStartDate = null; Date remindEndDate = null; if(map.get("remindstart")!=null) { Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart); remindStartDate = c.getTime(); map.put("remindstart", sdf.format(remindStartDate)); } if(map.get("remindend")!=null) { Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindEnd); remindEndDate = c.getTime(); map.put("remindend", sdf.format(remindEndDate)); } } Wrapper<ChangdiyuyueEntity> wrapper = new EntityWrapper<ChangdiyuyueEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } String tableName = request.getSession().getAttribute("tableName").toString(); if(tableName.equals("yonghu")) { wrapper.eq("zhanghao", (String)request.getSession().getAttribute("username")); } int count = changdiyuyueService.selectCount(wrapper); return R.ok().put("count", count); } }
最后
以上就是勤劳小刺猬最近收集整理的关于Java毕设项目——大学运动场地管理系统(java+SSM+Maven+Mysql+Jsp)一、前言介绍 二、系统功能分析 三、系统展示四、部分核心代码的全部内容,更多相关Java毕设项目——大学运动场地管理系统(java+SSM+Maven+Mysql+Jsp)一、前言介绍 二、系统功能分析 三、系统展示四、部分核心代码内容请搜索靠谱客的其他文章。
发表评论 取消回复