项目编号:BS-XCX-009
前言:
随着互联网的趋势的到来,各行各业都在考虑利用互联网将自己的信息推广出去,最好方式就是建立自己的平台信息,并对其进行管理,随着现在智能手机的普及,人们对于智能手机里面的应用旅游服务软件也在不断的使用,本文首先分析了旅游服务软件应用程序的需求,从系统开发环境、系统目标、设计流程、功能设计等几个方面对系统进行了系统设计。开发出本旅游服务软件,主要实现了管理员后端;首页、个人中心、旅游攻略管理、旅游资讯管理、景点信息管理、门票预定管理、用户管理、酒店信息管理、酒店预定管理、推荐路线管理、论坛管理、系统管理,用户前端;首页、景点信息、酒店信息、论坛中心、我的等。总体设计主要包括系统功能设计、该系统里充分综合应用Mysql数据库、JAVA等相关知识。网页界面的构成,具备简单易懂、便捷等特征。设计过程中,第一,静态页面的制作需要应用语言,以及APP的美工,在这些方面均收获了较好的成绩。第二,针对HBuilder X等技术动态编程以及数据库进行努力学习和大量实践,并运用到了APP的建设中。
一,环境介绍
语言环境:Java: jdk1.8
数据库:Mysql: mysql5.7
应用服务器:Tomcat: tomcat8.5.31
开发工具:IDEA或eclipse
二,项目简介
通过需求分析和设计出了旅游服务软件,实现首页、个人中心、旅游攻略管理、旅游资讯管理、景点信息管理、门票预定管理、用户管理、酒店信息管理、酒店预定管理、推荐路线管理、论坛管理、系统管理等功能,给用户提供一个完整的旅游服务软件资源平台。对旅游服务软件进行系统测试。
管理员、用户可通过HBuilder X系统手机打开系统,注册登录后可进行;
管理员;首页、个人中心、旅游攻略管理、旅游资讯管理、景点信息管理、门票预定管理、用户管理、酒店信息管理、酒店预定管理、推荐路线管理、论坛管理、系统管理等。
本系统的使用主要是为了给用户提供便利的查询旅游服务软件的平台,满足用户手机查询旅游服务软件的需求,促进旅游服务软件的发展。
总体分布如图3.1所示:
图3.1 总体功能需求图
用户用例图展示:
功能结构图:
系统开发流程图
数据库概念模型旨在抽象现实世界中的信息,实现信息世界的建模。因此,概念模型是数据库设计的重要工具。在概念模型设计、E-R模型的方法是最常用的设计方法。
根据系统功能模块的划分,对系统中的大部分实体进行了分析。系统的主要物理图如下:
1、酒店信息实体属性图如图4.4所示
图4.4酒店信息实体属性图
2、用户信息实体属性图如图4.5所示
图4.5用户信息实体属性图
3、景点信息实体属性图如图4.5所示
图4.6景点信息实体属性图
三,系统展示
5.1管理员登录模块
管理员通过页面输入用户名、密码、角色进行登录操作,如图5-1所示。
5.2管理员后端功能模块
管理员通过页面进行登录操作,登陆系统后,可以查看首页、个人中心、旅游攻略管理、旅游资讯管理、景点信息管理、门票预定管理、用户管理、酒店信息管理、酒店预定管理、推荐路线管理、论坛管理、系统管理等模块进行查看、编辑修改操作;如图5-2所示。
图5-2管理员功能界面图
旅游资讯管理:通过内容列表可以获取资讯标题、封面图片、发布时间等信息,进行查看详情、修改、删除操作,如图5-3所示;
图5-3旅游资讯管理界图面
景点信息管理:通过内容列表可以获取景点名称、等级、景点图片、门票价格、开放时间、服务电话等进行详情或修改、删除操作,如图5-4所示;
图5-4景点信息管理界图面
用户管理:通过内容列表可以获取用户账号、密码、用户姓名、头像、手机号、身份证等信息,进行查看、修改、删除操作,如图5-5所示;
图5-5用户管理界图面
酒店信息管理:通过内容列表可以获取酒店名称、类别、星级、酒店图片、酒店地址、房间类型、一晚价格、联系电话等信息,进行查看、修改、删除操作,如图5-6所示;
图5-6酒店信息管理界图面
前端功能展示:
首页
用户登录到首页可以查看首页、景点信息、酒店信息、论坛中心、我的等内容,如图5.13所示。
图5.13首页功能界面图
我的
在我的页面可以查看旅游攻略、景点信息、门票预定、酒店信息、酒店预定、推荐路线、我要发帖等信息,如图5.14所示。
图5.14我的界面图
用户信息
在用户信息页面可以查看用户账号、密码、用户姓名 头像、手机号等信息,并可根据需要进行保存,如图5.15所示。
图5.15用户信息界面图
旅游攻略
在旅游攻略可以查看攻略标题、发布时间、图片、用户账号、攻略内容等信息,并可根据需要对旅游攻略进行提交,如图5.16所示。
5.16旅游攻略界面图
景点信息
在景点信息页面可以查看景点名称、等级、景点图片、门票价格、开放时间、服务电话、详细地址等信息,并可根据需要对景点信息进行门票预订,如图5.17所示。
图5.17景点信息界面图
酒店信息
在酒店信息页面可以查看酒店名称、类别、星级、酒店图片、酒店地址、房间类型、一晚价格、联系电话等内容,并可根据需要进行酒店预订,如图5.18所示。
图5.18酒店信息界面图
门票预定
在门票预定页面可以查看景点名称、等级、详细地址、门票价格、购买数量、总价格等内容,并可根据需要进行支付,如图5.19所示。
图5.19门票预定界面图
四,核心代码展示
package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.JingdianxinxiEntity; import com.entity.view.JingdianxinxiView; import com.service.JingdianxinxiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 景点信息 * 后端接口 * @author * @email * @date 2020-12-29 11:11:16 */ @RestController @RequestMapping("/jingdianxinxi") public class JingdianxinxiController { @Autowired private JingdianxinxiService jingdianxinxiService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,JingdianxinxiEntity jingdianxinxi, HttpServletRequest request){ EntityWrapper<JingdianxinxiEntity> ew = new EntityWrapper<JingdianxinxiEntity>(); PageUtils page = jingdianxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jingdianxinxi), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @IgnoreAuth @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,JingdianxinxiEntity jingdianxinxi, HttpServletRequest request){ EntityWrapper<JingdianxinxiEntity> ew = new EntityWrapper<JingdianxinxiEntity>(); PageUtils page = jingdianxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jingdianxinxi), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( JingdianxinxiEntity jingdianxinxi){ EntityWrapper<JingdianxinxiEntity> ew = new EntityWrapper<JingdianxinxiEntity>(); ew.allEq(MPUtil.allEQMapPre( jingdianxinxi, "jingdianxinxi")); return R.ok().put("data", jingdianxinxiService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(JingdianxinxiEntity jingdianxinxi){ EntityWrapper< JingdianxinxiEntity> ew = new EntityWrapper< JingdianxinxiEntity>(); ew.allEq(MPUtil.allEQMapPre( jingdianxinxi, "jingdianxinxi")); JingdianxinxiView jingdianxinxiView = jingdianxinxiService.selectView(ew); return R.ok("查询景点信息成功").put("data", jingdianxinxiView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") String id){ JingdianxinxiEntity jingdianxinxi = jingdianxinxiService.selectById(id); return R.ok().put("data", jingdianxinxi); } /** * 前端详情 */ @IgnoreAuth @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") String id){ JingdianxinxiEntity jingdianxinxi = jingdianxinxiService.selectById(id); return R.ok().put("data", jingdianxinxi); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody JingdianxinxiEntity jingdianxinxi, HttpServletRequest request){ jingdianxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jingdianxinxi); jingdianxinxiService.insert(jingdianxinxi); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody JingdianxinxiEntity jingdianxinxi, HttpServletRequest request){ jingdianxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jingdianxinxi); jingdianxinxiService.insert(jingdianxinxi); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody JingdianxinxiEntity jingdianxinxi, HttpServletRequest request){ //ValidatorUtils.validateEntity(jingdianxinxi); jingdianxinxiService.updateById(jingdianxinxi);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ jingdianxinxiService.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<JingdianxinxiEntity> wrapper = new EntityWrapper<JingdianxinxiEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } int count = jingdianxinxiService.selectCount(wrapper); return R.ok().put("count", count); } }
package com.controller; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Arrays; import java.util.Calendar; import java.util.Map; import java.util.HashMap; import java.util.Iterator; import java.util.Date; import java.util.List; import javax.servlet.http.HttpServletRequest; import com.utils.ValidatorUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.annotation.IgnoreAuth; import com.entity.JiudianxinxiEntity; import com.entity.view.JiudianxinxiView; import com.service.JiudianxinxiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 酒店信息 * 后端接口 * @author * @email * @date 2020-12-29 11:11:16 */ @RestController @RequestMapping("/jiudianxinxi") public class JiudianxinxiController { @Autowired private JiudianxinxiService jiudianxinxiService; /** * 后端列表 */ @RequestMapping("/page") public R page(@RequestParam Map<String, Object> params,JiudianxinxiEntity jiudianxinxi, HttpServletRequest request){ EntityWrapper<JiudianxinxiEntity> ew = new EntityWrapper<JiudianxinxiEntity>(); PageUtils page = jiudianxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiudianxinxi), params), params)); return R.ok().put("data", page); } /** * 前端列表 */ @IgnoreAuth @RequestMapping("/list") public R list(@RequestParam Map<String, Object> params,JiudianxinxiEntity jiudianxinxi, HttpServletRequest request){ EntityWrapper<JiudianxinxiEntity> ew = new EntityWrapper<JiudianxinxiEntity>(); PageUtils page = jiudianxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiudianxinxi), params), params)); return R.ok().put("data", page); } /** * 列表 */ @RequestMapping("/lists") public R list( JiudianxinxiEntity jiudianxinxi){ EntityWrapper<JiudianxinxiEntity> ew = new EntityWrapper<JiudianxinxiEntity>(); ew.allEq(MPUtil.allEQMapPre( jiudianxinxi, "jiudianxinxi")); return R.ok().put("data", jiudianxinxiService.selectListView(ew)); } /** * 查询 */ @RequestMapping("/query") public R query(JiudianxinxiEntity jiudianxinxi){ EntityWrapper< JiudianxinxiEntity> ew = new EntityWrapper< JiudianxinxiEntity>(); ew.allEq(MPUtil.allEQMapPre( jiudianxinxi, "jiudianxinxi")); JiudianxinxiView jiudianxinxiView = jiudianxinxiService.selectView(ew); return R.ok("查询酒店信息成功").put("data", jiudianxinxiView); } /** * 后端详情 */ @RequestMapping("/info/{id}") public R info(@PathVariable("id") String id){ JiudianxinxiEntity jiudianxinxi = jiudianxinxiService.selectById(id); return R.ok().put("data", jiudianxinxi); } /** * 前端详情 */ @IgnoreAuth @RequestMapping("/detail/{id}") public R detail(@PathVariable("id") String id){ JiudianxinxiEntity jiudianxinxi = jiudianxinxiService.selectById(id); return R.ok().put("data", jiudianxinxi); } /** * 后端保存 */ @RequestMapping("/save") public R save(@RequestBody JiudianxinxiEntity jiudianxinxi, HttpServletRequest request){ jiudianxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jiudianxinxi); jiudianxinxiService.insert(jiudianxinxi); return R.ok(); } /** * 前端保存 */ @RequestMapping("/add") public R add(@RequestBody JiudianxinxiEntity jiudianxinxi, HttpServletRequest request){ jiudianxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jiudianxinxi); jiudianxinxiService.insert(jiudianxinxi); return R.ok(); } /** * 修改 */ @RequestMapping("/update") public R update(@RequestBody JiudianxinxiEntity jiudianxinxi, HttpServletRequest request){ //ValidatorUtils.validateEntity(jiudianxinxi); jiudianxinxiService.updateById(jiudianxinxi);//全部更新 return R.ok(); } /** * 删除 */ @RequestMapping("/delete") public R delete(@RequestBody Long[] ids){ jiudianxinxiService.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<JiudianxinxiEntity> wrapper = new EntityWrapper<JiudianxinxiEntity>(); if(map.get("remindstart")!=null) { wrapper.ge(columnName, map.get("remindstart")); } if(map.get("remindend")!=null) { wrapper.le(columnName, map.get("remindend")); } int count = jiudianxinxiService.selectCount(wrapper); return R.ok().put("count", count); } }
五,项目总结
未注册用户可进入注册界面,填写用户信息,若用户名存在的话,提示返回填写用户名,用户名不存在,则填写密码和手机号,如果电话号码是有效的,用户信息被添加到数据库,注册成功。用户注册流程图如图3.2所示。
图3.2 系统注册流程图
为了保证系统的安全性,要使用本系统必须先登陆到系统中。用户在登录界面输入用户名和密码,点击登录,进入系统,其登录的流程图如图3.3所示。
图3.3系统登录流程图