旅游平台|基于java的智慧旅游平台设计与实现(源码+数据库+文档)

旅游平台|基于java的智慧旅游平台设计与实现(源码+数据库+文档) 智慧旅游平台目录基于java的智慧旅游平台设计与实现一、前言二、系统功能设计三、系统实现四、数据库设计五、核心代码六、论文参考七、最新计算机毕设选题推荐八、源码获取博主介绍✌️大厂码农|毕设布道师阿里云开发社区乘风者计划专家博主CSDN平台Java领域优质创作者专注于大学生项目实战开发、讲解和毕业答疑辅导。✌️主要项目小程序、SpringBoot、SSM、Vue、Html、Jsp、Nodejs等设计与开发。文末获取源码联系基于java的智慧旅游平台设计与实现一、前言在设计智慧旅游平台时功能模块充分融合了用户与管理员的实际需求实现了多元化且全面的闲置智慧旅游功能。本智慧旅游平台开发微信小程序功能有管理员和用户。管理员功能有个人中心用户管理景点分类管理旅游景点管理景点购票管理景区活动管理留言板管理系统管理。用户可以查看景点信息活动信息还可以购票以及留言。因而具有一定的实用性。本站后台采用Java的SSM框架进行后台管理开发可以在浏览器上登录进行后台数据方面的管理MySQL作为本地数据库微信小程序用到了微信开发者工具充分保证系统的稳定性。系统具有界面清晰、操作简单功能齐全的特点使得智慧旅游平台开发微信小程序管理工作系统化、规范化。关键词智慧旅游平台开发微信小程序SSM框架MYSQL数据库二、系统功能设计三、系统实现管理员可以管理用户信息可以对用户信息添加修改删除。具体界面的展示如图5.1所示。图5.1 用户信息界面管理员可以对景区活动信息进行添加修改删除操作。界面如下图所示图5.4 景区活动管理界面管理员可以对旅游景点信息进行添加修改删除操作。具体界面如图5.2所示。图5.3 旅游景点信息管理界面小程序用户是需要注册才可以进行登录的登录后在首页可以查看相关信息并且下面导航可以点击到其他功能模块。界面如下图所示图5.5 系统首页用户可以对景点进行购票操作。界面如下图所示图5.6 景点购票界面四、数据库设计1景点分类信息的实体属性图如下图4.12 景点分类信息实体属性图2通知旅游资讯属性图如图4.13所示图4.13旅游资讯实体属性图表4. 1景区活动评论表字段类型空默认注释id (主键)bigint(20)否主键addtimetimestamp否CURRENT_TIMESTAMP创建时间refidbigint(20)否关联表iduseridbigint(20)否用户idnicknamevarchar(200)是NULL用户名contentlongtext否评论内容replylongtext是NULL回复内容表4.2 旅游景点评论表字段类型空默认注释id (主键)bigint(20)否主键addtimetimestamp否CURRENT_TIMESTAMP创建时间refidbigint(20)否关联表iduseridbigint(20)否用户idnicknamevarchar(200)是NULL用户名contentlongtext否评论内容replylongtext是NULL回复内容表4.3 景点分类字段类型空默认注释id (主键)bigint(20)否主键addtimetimestamp否CURRENT_TIMESTAMP创建时间fenleivarchar(200)否分类表4. 4景点购票字段类型空默认注释id (主键)bigint(20)否主键addtimetimestamp否CURRENT_TIMESTAMP创建时间dingdanbianhaovarchar(200)是NULL订单编号jingdianmingchengvarchar(200)是NULL景点名称fenleivarchar(200)是NULL分类jingdiantupianvarchar(200)是NULL景点图片jingdiandizhivarchar(200)是NULL景点地址menpiaojiageint(11)是NULL门票价格shuliangint(11)是NULL数量zongjinevarchar(200)是NULL总金额goupiaoriqidate是NULL购票日期yonghumingvarchar(200)是NULL用户名shoujivarchar(200)是NULL手机shenfenzhengvarchar(200)是NULL身份证sfshvarchar(200)是否是否审核shhflongtext是NULL审核回复ispayvarchar(200)是未支付是否支付useridbigint(20)是NULL用户id五、核心代码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.format.annotation.DateTimeFormat; 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.BumenEntity; import com.entity.view.BumenView; import com.service.BumenService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 部门 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/bumen) public class BumenController { Autowired private BumenService bumenService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,BumenEntity bumen, HttpServletRequest request){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); PageUtils page bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,BumenEntity bumen, HttpServletRequest request){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); PageUtils page bumenService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, bumen), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( BumenEntity bumen){ EntityWrapperBumenEntity ew new EntityWrapperBumenEntity(); ew.allEq(MPUtil.allEQMapPre( bumen, bumen)); return R.ok().put(data, bumenService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(BumenEntity bumen){ EntityWrapper BumenEntity ew new EntityWrapper BumenEntity(); ew.allEq(MPUtil.allEQMapPre( bumen, bumen)); BumenView bumenView bumenService.selectView(ew); return R.ok(查询部门成功).put(data, bumenView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ BumenEntity bumen bumenService.selectById(id); return R.ok().put(data, bumen); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ BumenEntity bumen bumenService.selectById(id); return R.ok().put(data, bumen); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody BumenEntity bumen, HttpServletRequest request){ bumen.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(bumen); bumenService.insert(bumen); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody BumenEntity bumen, HttpServletRequest request){ //ValidatorUtils.validateEntity(bumen); bumenService.updateById(bumen);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ bumenService.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 MapString, 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)); } } WrapperBumenEntity wrapper new EntityWrapperBumenEntity(); if(map.get(remindstart)!null) { wrapper.ge(columnName, map.get(remindstart)); } if(map.get(remindend)!null) { wrapper.le(columnName, map.get(remindend)); } int count bumenService.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.format.annotation.DateTimeFormat; 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.GangweiEntity; import com.entity.view.GangweiView; import com.service.GangweiService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 岗位 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/gangwei) public class GangweiController { Autowired private GangweiService gangweiService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); PageUtils page gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,GangweiEntity gangwei, HttpServletRequest request){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); PageUtils page gangweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, gangwei), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( GangweiEntity gangwei){ EntityWrapperGangweiEntity ew new EntityWrapperGangweiEntity(); ew.allEq(MPUtil.allEQMapPre( gangwei, gangwei)); return R.ok().put(data, gangweiService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(GangweiEntity gangwei){ EntityWrapper GangweiEntity ew new EntityWrapper GangweiEntity(); ew.allEq(MPUtil.allEQMapPre( gangwei, gangwei)); GangweiView gangweiView gangweiService.selectView(ew); return R.ok(查询岗位成功).put(data, gangweiView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ GangweiEntity gangwei gangweiService.selectById(id); return R.ok().put(data, gangwei); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ GangweiEntity gangwei gangweiService.selectById(id); return R.ok().put(data, gangwei); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody GangweiEntity gangwei, HttpServletRequest request){ gangwei.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(gangwei); gangweiService.insert(gangwei); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody GangweiEntity gangwei, HttpServletRequest request){ //ValidatorUtils.validateEntity(gangwei); gangweiService.updateById(gangwei);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ gangweiService.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 MapString, 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)); } } WrapperGangweiEntity wrapper new EntityWrapperGangweiEntity(); if(map.get(remindstart)!null) { wrapper.ge(columnName, map.get(remindstart)); } if(map.get(remindend)!null) { wrapper.le(columnName, map.get(remindend)); } int count gangweiService.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.format.annotation.DateTimeFormat; 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.JixiaokaoheEntity; import com.entity.view.JixiaokaoheView; import com.service.JixiaokaoheService; import com.service.TokenService; import com.utils.PageUtils; import com.utils.R; import com.utils.MD5Util; import com.utils.MPUtil; import com.utils.CommonUtil; /** * 绩效考核 * 后端接口 * author * email * date 2021-05-07 10:42:31 */ RestController RequestMapping(/jixiaokaohe) public class JixiaokaoheController { Autowired private JixiaokaoheService jixiaokaoheService; /** * 后端列表 */ RequestMapping(/page) public R page(RequestParam MapString, Object params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ String tableName request.getSession().getAttribute(tableName).toString(); if(tableName.equals(yuangong)) { jixiaokaohe.setYuangonggonghao((String)request.getSession().getAttribute(username)); } EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); PageUtils page jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put(data, page); } /** * 前端列表 */ RequestMapping(/list) public R list(RequestParam MapString, Object params,JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); PageUtils page jixiaokaoheService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jixiaokaohe), params), params)); return R.ok().put(data, page); } /** * 列表 */ RequestMapping(/lists) public R list( JixiaokaoheEntity jixiaokaohe){ EntityWrapperJixiaokaoheEntity ew new EntityWrapperJixiaokaoheEntity(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, jixiaokaohe)); return R.ok().put(data, jixiaokaoheService.selectListView(ew)); } /** * 查询 */ RequestMapping(/query) public R query(JixiaokaoheEntity jixiaokaohe){ EntityWrapper JixiaokaoheEntity ew new EntityWrapper JixiaokaoheEntity(); ew.allEq(MPUtil.allEQMapPre( jixiaokaohe, jixiaokaohe)); JixiaokaoheView jixiaokaoheView jixiaokaoheService.selectView(ew); return R.ok(查询绩效考核成功).put(data, jixiaokaoheView); } /** * 后端详情 */ RequestMapping(/info/{id}) public R info(PathVariable(id) Long id){ JixiaokaoheEntity jixiaokaohe jixiaokaoheService.selectById(id); return R.ok().put(data, jixiaokaohe); } /** * 前端详情 */ RequestMapping(/detail/{id}) public R detail(PathVariable(id) Long id){ JixiaokaoheEntity jixiaokaohe jixiaokaoheService.selectById(id); return R.ok().put(data, jixiaokaohe); } /** * 后端保存 */ RequestMapping(/save) public R save(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 前端保存 */ RequestMapping(/add) public R add(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ jixiaokaohe.setId(new Date().getTime()new Double(Math.floor(Math.random()*1000)).longValue()); //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.insert(jixiaokaohe); return R.ok(); } /** * 修改 */ RequestMapping(/update) public R update(RequestBody JixiaokaoheEntity jixiaokaohe, HttpServletRequest request){ //ValidatorUtils.validateEntity(jixiaokaohe); jixiaokaoheService.updateById(jixiaokaohe);//全部更新 return R.ok(); } /** * 删除 */ RequestMapping(/delete) public R delete(RequestBody Long[] ids){ jixiaokaoheService.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 MapString, 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)); } } WrapperJixiaokaoheEntity wrapper new EntityWrapperJixiaokaoheEntity(); 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(yuangong)) { wrapper.eq(yuangonggonghao, (String)request.getSession().getAttribute(username)); } int count jixiaokaoheService.selectCount(wrapper); return R.ok().put(count, count); } }六、论文参考七、最新计算机毕设选题推荐最新计算机软件毕业设计选题大全-CSDN博客八、源码获取大家点赞、收藏、关注、评论啦 、获取联系方式在文章末尾