博主主页:一季春秋
博主简介:专注Java技术领域和毕业设计项目实战、Java、微信小程序、安卓等技术开发,远程调试部署、代码讲解、文档指导、ppt制作等技术指导。
主要内容:毕业设计(Java项目、小程序等)、简历模板、学习资料、面试题库、技术咨询。🍅文末获取联系🍅
精彩专栏推荐订阅👇🏻👇🏻 不然下次找不到哟
SpringBoot+Vue项目持续更新中
目录
一、项目介绍
本系统结合计算机系统的结构、概念、模型、原理、方法,在计算机各种优势的情况下,采用JAVA语言,结合SpringBoot框架与Vue框架以及MYSQL数据库设计并实现的。本贵州旅游系统主要包括个人中心、用户管理、商品分类管理、风景名胜管理、酒店信息管理、车辆信息管理、食文化管理等多个模块。它帮助贵州旅游管理实现了信息化、网络化,通过测试,实现了系统设计目标,相比传统的管理模式,本系统合理的利用了贵州旅游管理数据资源,有效的减少了贵州旅游管理的经济投入,大大提高了贵州旅游管理的效率。
二、项目主要技术
开发语言:Java
使用框架:spring boot
前端技术:JavaScript、Vue 、css3
开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code
数据库:MySQL 5.7/8.0
数据库管理工具:phpstudy/Navicat
JDK版本:jdk1.8
Maven: apache-maven 3.8.1-bin
三、系统设计
在系统分析的基础上,本章首先介绍了系统的总体功能设计,详细描述了系统的不同模块,然后对系统的数据库设计进行了E-R图的转换,并且给出了各个功能模块的表设计。
3.1 系统总体功能设计
通过软件的需求分析已经获得了系统的基本功能需求,根据需求,将贵州旅游系统功能模块主要分为管理员模块。管理员添加个人中心、用户管理、商品分类管理、风景名胜管理、酒店信息管理、车辆信息管理、食文化管理、黔之味管理、门票预订管理、酒店预订管理、租车预订管理、酒店取消管理、门票取消管理、取消租车管理、在线留言、系统管理、订单管理等操作。如图是系统的功能结构图。
3.2 管理员模块
管理员模块可以进行个人中心,对其进行增删改查操作,系统用户的属性包括用户名、密码、权限、添加时间;对进行用户管理,可以添加用户,将信息记录表中,经过添加后,此用户可以被用户管理查看,可以对信息进行更新,将信息从表中进行删除;对进行商品分类管理,可以添加商品分类信息,对商品分类信息列表进行查询,对商品分类信息进行修改以及将商品分类信息从列表删除。可以管理风景名胜,并对风景名胜信息列表进行查询,对风景名胜信息进行修改以及删除。对进行酒店信息管理,可以添加酒店信息管理,对酒店信息管理列表进行查询,对酒店信息管理进行修改以及将酒店信息管理从列表删除。可以管理车辆信息管理,并对车辆信息管理列表进行查询,对车辆信息管理进行修改以及删除。对进行食文化管理,可以添加食文化信息,对食文化列表进行查询,对食文化进行修改以及将食文化信息从列表删除。可以管理黔之味,并对黔之味列表进行查询,对黔之味进行修改以及删除;对进行门票预订管理,可以添加门票预订,对门票预订列表进行查询,对门票预订进行修改以及将门票预订管理从列表删除。可以管理酒店预订,并对酒店预订列表进行查询,对酒店预订进行修改以及删除
如图是以对用户管理为例的活动图。
四、系统实现
4.1 前台用户功能实现
首页界面
风景名胜推荐界面
酒店信息界面
酒店信息
车辆信息
黔之味界面
4.2 管理员模块实现
管理员输入用户名和密码,下拉选择框,选择用户权限,然后点击立即登录,系统与保存在数据库的数据进行匹配,如果用户名与密码与数据库存放数据匹配,系统跳转到用户页面,否则提示错误重新跳转到登录页面。
系统登录界面
用户管理是可以进行添加用户信息操作。在文本框输入所要添加的用户管理,然后提交即可,输入错误可以点击重置按钮对文本框重置。
用户管理界面
风景名胜管理是可以进行添加风景名胜信息操作。添加风景名胜信息时,需要设置风景名胜信息,然后提交即可,输入错误可以点击重置按钮对文本框重置。
风景名胜管理界面
查询所有酒店信息列表,查询酒店信息,并对酒店信息进行修改,可以对列表中酒店信息进行删除。
酒店信息查询界面
黔之味管理是可以列表中进行添加黔之味管理信息操作。添加黔之味管理信息时,需要设置黔之味管理基本信息,然后提交即可,输入错误可以点击重置按钮对文本框重置。
黔之味管理信息界面
询所有门票预订管理信息列表,查询门票预订管理信息,并对门票预订管理信息进行修改,可以对列表中门票预订管理信息进行删除。
门票预订管理信息界面
订单管理界面
五、实现代码
5.1 协同算法关键代码
/**
* 协同算法(按用户购买推荐)
*/
@RequestMapping("/autoSort2")
public R autoSort2(@RequestParam Map<String, Object> params,QianzhiweiEntity qianzhiwei, HttpServletRequest request){
String userId = request.getSession().getAttribute("userId").toString();
String goodtypeColumn = "shangpinfenlei";
List<OrdersEntity> orders = ordersService.selectList(new EntityWrapper<OrdersEntity>().eq("userid", userId).eq("tablename", "qianzhiwei").orderBy("addtime", false));
List<String> goodtypes = new ArrayList<String>();
Integer limit = params.get("limit")==null?10:Integer.parseInt(params.get("limit").toString());
List<QianzhiweiEntity> qianzhiweiList = new ArrayList<QianzhiweiEntity>();
//去重
List<OrdersEntity> ordersDist = new ArrayList<OrdersEntity>();
for(OrdersEntity o1 : orders) {
boolean addFlag = true;
for(OrdersEntity o2 : ordersDist) {
if(o1.getGoodid()==o2.getGoodid() || o1.getGoodtype().equals(o2.getGoodtype())) {
addFlag = false;
break;
}
}
if(addFlag) ordersDist.add(o1);
}
if(ordersDist!=null && ordersDist.size()>0) {
for(OrdersEntity o : ordersDist) {
qianzhiweiList.addAll(qianzhiweiService.selectList(new EntityWrapper<QianzhiweiEntity>().eq(goodtypeColumn, o.getGoodtype())));
}
}
EntityWrapper<QianzhiweiEntity> ew = new EntityWrapper<QianzhiweiEntity>();
params.put("sort", "id");
params.put("order", "desc");
PageUtils page = qianzhiweiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, qianzhiwei), params), params));
List<QianzhiweiEntity> pageList = (List<QianzhiweiEntity>)page.getList();
if(qianzhiweiList.size()<limit) {
int toAddNum = (limit-qianzhiweiList.size())<=pageList.size()?(limit-qianzhiweiList.size()):pageList.size();
for(QianzhiweiEntity o1 : pageList) {
boolean addFlag = true;
for(QianzhiweiEntity o2 : qianzhiweiList) {
if(o1.getId().intValue()==o2.getId().intValue()) {
addFlag = false;
break;
}
}
if(addFlag) {
qianzhiweiList.add(o1);
if(--toAddNum==0) break;
}
}
} else if(qianzhiweiList.size()>limit) {
qianzhiweiList = qianzhiweiList.subList(0, limit);
}
page.setList(qianzhiweiList);
return R.ok().put("data", page);
}
}
5.2 订单统计关键代码
/**
* (按值统计)
*/
@RequestMapping("/value/{xColumnName}/{yColumnName}")
public R value(@PathVariable("yColumnName") String yColumnName, @PathVariable("xColumnName") String xColumnName,HttpServletRequest request) {
Map<String, Object> params = new HashMap<String, Object>();
params.put("xColumn", xColumnName);
params.put("yColumn", yColumnName);
EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
ew.in("status", new String[]{"已支付","已发货","已完成"});
List<Map<String, Object>> result = ordersService.selectValue(params, ew);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
for(Map<String, Object> m : result) {
for(String k : m.keySet()) {
if(m.get(k) instanceof Date) {
m.put(k, sdf.format((Date)m.get(k)));
}
}
}
return R.ok().put("data", result);
}
/**
* (按值统计)时间统计类型
*/
@RequestMapping("/value/{xColumnName}/{yColumnName}/{timeStatType}")
public R valueDay(@PathVariable("yColumnName") String yColumnName, @PathVariable("xColumnName") String xColumnName, @PathVariable("timeStatType") String timeStatType,HttpServletRequest request) {
Map<String, Object> params = new HashMap<String, Object>();
params.put("xColumn", xColumnName);
params.put("yColumn", yColumnName);
params.put("timeStatType", timeStatType);
EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
ew.in("status", new String[]{"已支付","已发货","已完成"});
List<Map<String, Object>> result = ordersService.selectTimeStatValue(params, ew);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
for(Map<String, Object> m : result) {
for(String k : m.keySet()) {
if(m.get(k) instanceof Date) {
m.put(k, sdf.format((Date)m.get(k)));
}
}
}
return R.ok().put("data", result);
}
/**
* 分组统计
*/
@RequestMapping("/group/{columnName}")
public R group(@PathVariable("columnName") String columnName,HttpServletRequest request) {
Map<String, Object> params = new HashMap<String, Object>();
params.put("column", columnName);
EntityWrapper<OrdersEntity> ew = new EntityWrapper<OrdersEntity>();
ew.in("status", new String[]{"已支付","已发货","已完成"});
List<Map<String, Object>> result = ordersService.selectGroup(params, ew);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
for(Map<String, Object> m : result) {
for(String k : m.keySet()) {
if(m.get(k) instanceof Date) {
m.put(k, sdf.format((Date)m.get(k)));
}
}
}
return R.ok().put("data", result);
}
}