💕💕作者:计算机源码社
💕💕个人简介:本人七年开发经验,擅长Java、微信小程序、Python、Android等,大家有这一块的问题可以一起交流!
💕💕学习资料、程序开发、技术解答、代码讲解、文档报告
1、绪论
1.1 项目背景
随着科技技术的不断发展,互联网技术和体育产业的结合,不仅能为人们提供更加便捷、人性化的体育服务,还有助于促进不同体育产业方向的结合。首先,传统的乒乓球公园场地预约模式在现今科技社会显得较为落后,既不便利且又浪费时间。其次,多数体育的热门运动项目场地经常处于爆满状态,很难保证到达场地后有空余场地,尤其是国球——乒乓球场地。最后,一般线下预定又比较繁琐,很难做到场地的便捷预定,而且鉴于在乒乓球场地预定方面和互联网结合较少,尤其是在平台很少有以乒乓球场地预定为主题的互联网解决方案。为此本次课题将研究开发一个基于SpringBoot+Vue的乒乓球场地预约系统。
1.2 项目意义
步入21世纪科技的时代,无论生活、工作还是学习均朝着网络化、信息化方向发展。由于当代中国科技技术发展速度加快,伴随着许多新兴的产业诞生以及模式发生改变。随着人们生活水平的不断提高,人们对生活的追求不仅限于吃饱,而是更加注重运动方面。人们利用生活闲暇时间进行体育运动已经是人们日常的生活习惯。同时,运动也是人们在社交的一种方式,会在不同的运动中结识很多志同道合的朋友。但在城市中生活,有些运动需要设备健全的场所才能进行,例如乒乓球运动都需要在乒乓球场地中进行。传统的乒乓球场地预约则是需要亲自到场地咨询是否有空余场地,若有则可入场打球,否则则需要预约明日时间,这种形式极不方便且也花费了大量时间和金钱。因此,结合21世纪的科技技术,利用网络化、信息化应用于乒乓球场地预约,让人们通过手机、电脑可以提前了解乒乓球场地的使用情况,根据自身需求进行预约。这不仅让人们节省时间,还不可以预约到想预约场地进行运动。
2、核心功能模块
<font size=4px> 基于SpringBoot+Vue的乒乓球场地预约系统采用B/S的结构,Java语言进行设计,后台上采用Mysql数据库。
乒乓球场地预约系统的主要使用者分为管理员和用户,实现功能包括:
①管理员功能:首页、个人中心、用户管理、乒乓球场管理、场地类型管理、场地预约管理、暂离申请管理、离开申请管理、留言反馈管理、系统管理。
②用户功能:注册、登录、查看乒乓球场信息、查看球场状态是否空闲、在线留言反馈、查看公告信息、评论、收藏、个人信息管理、预约乒乓球场、暂离申请、离开申请、等操作。
3、项目页面展示
4、 核心代码
**
* 乒乓球场
* 后端接口
*/
@RestController
@RequestMapping("/pingpangqiuchang")
public class PingpangqiuchangController {
@Autowired
private PingpangqiuchangService pingpangqiuchangService;
@Autowired
private StoreupService storeupService;
/**
* 后端乒乓球场地列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,PingpangqiuchangEntity pingpangqiuchang,
HttpServletRequest request){
EntityWrapper<PingpangqiuchangEntity> ew = new EntityWrapper<PingpangqiuchangEntity>();
PageUtils page = pingpangqiuchangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, pingpangqiuchang), params), params));
return R.ok().put("data", page);
}
/**
* 前端乒乓球场地列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,PingpangqiuchangEntity pingpangqiuchang,
HttpServletRequest request){
EntityWrapper<PingpangqiuchangEntity> ew = new EntityWrapper<PingpangqiuchangEntity>();
PageUtils page = pingpangqiuchangService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, pingpangqiuchang), params), params));
return R.ok().put("data", page);
}
/**
* 乒乓球场地列表
*/
@RequestMapping("/lists")
public R list( PingpangqiuchangEntity pingpangqiuchang){
EntityWrapper<PingpangqiuchangEntity> ew = new EntityWrapper<PingpangqiuchangEntity>();
ew.allEq(MPUtil.allEQMapPre( pingpangqiuchang, "pingpangqiuchang"));
return R.ok().put("data", pingpangqiuchangService.selectListView(ew));
}
/**
* 查询乒乓球场地
*/
@RequestMapping("/query")
public R query(PingpangqiuchangEntity pingpangqiuchang){
EntityWrapper< PingpangqiuchangEntity> ew = new EntityWrapper< PingpangqiuchangEntity>();
ew.allEq(MPUtil.allEQMapPre( pingpangqiuchang, "pingpangqiuchang"));
PingpangqiuchangView pingpangqiuchangView = pingpangqiuchangService.selectView(ew);
return R.ok("查询乒乓球场成功").put("data", pingpangqiuchangView);
}
/**
* 后端乒乓球场地详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
PingpangqiuchangEntity pingpangqiuchang = pingpangqiuchangService.selectById(id);
return R.ok().put("data", pingpangqiuchang);
}
/**
* 前端乒乓球场地详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
PingpangqiuchangEntity pingpangqiuchang = pingpangqiuchangService.selectById(id);
return R.ok().put("data", pingpangqiuchang);
}
/**
* 后端保存乒乓球场地
*/
@RequestMapping("/save")
public R save(@RequestBody PingpangqiuchangEntity pingpangqiuchang, HttpServletRequest request){
pingpangqiuchang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(pingpangqiuchang);
pingpangqiuchangService.insert(pingpangqiuchang);
return R.ok();
}
/**
* 前端保存乒乓球场地
*/
@RequestMapping("/add")
public R add(@RequestBody PingpangqiuchangEntity pingpangqiuchang, HttpServletRequest request){
pingpangqiuchang.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(pingpangqiuchang);
pingpangqiuchangService.insert(pingpangqiuchang);
return R.ok();
}
/**
* 修改乒乓球场地
*/
@RequestMapping("/update")
@Transactional
public R update(@RequestBody PingpangqiuchangEntity pingpangqiuchang, HttpServletRequest request){
//ValidatorUtils.validateEntity(pingpangqiuchang);
pingpangqiuchangService.updateById(pingpangqiuchang);//全部更新
return R.ok();
}
/**
* 删除乒乓球场地
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
pingpangqiuchangService.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<PingpangqiuchangEntity> wrapper = new EntityWrapper<PingpangqiuchangEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = pingpangqiuchangService.selectCount(wrapper);
return R.ok().put("count", count);
}