酒店信息管理项目——结合数据库使用的任务调度
这个项目是本人在工作之余利用闲暇时间进行开发的,主要是为了弥补大学毕业设计的遗憾(本人并不是没有过_,只是没有做自己喜欢的毕业设计)。酒店信息管理系统是一个前后端分离项目,前端使用vue,后端使用java开发,开发完后部署在云服务器上。
废话少说直接上项目地址,http://121.43.170.105:8004
账号:black 密码:root (也可以自行注册)
如果有不明白可以看我的主页关于酒店信息管理项目系列的文章
前言
有需要代码的小伙伴私信我WX: 1208191350
一、项目结构和技术栈的使用
项目的整体结构采用的是前后端分离的形式:
后端框架的使用:spring-boot maven mybatis-plus mybatisX
后端技术栈的使用:
1.JWT令牌权限校验与授权登录
2.短信验证码登录,使用阿里云短信服务
3.swagger api接口文档生成器
4.mybatis-plus-generator 代码生成
5.七牛云图片上传服务,将图片保存到三方服务器
6.结合数据库使用spring-boot的定时调度任务
7.redis进行短信验证码的验证,和JWT令牌(Token)的激活(保活)
后台项目结构:
前端框架的使用:vue-cli3 element-ui vue-router
前端技术栈的使用:html css scss js vue axsio
前端项目结构:
二、功能介绍
1结合数据库使用的任务调度
1.1新建任务调度类:
package com.hotel.task;
import com.hotel.IScheduleSettingService;
import com.hotel.entity.ScheduleSetting;
import com.hotel.mapper.CustomerMapper;
import com.hotel.mapper.RoomMapper;
import lombok.SneakyThrows;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.Trigger;
import org.springframework.scheduling.TriggerContext;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
import org.springframework.scheduling.support.CronTrigger;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import java.time.LocalDateTime;
import java.util.Date;
import java.util.List;
/**
* User: codeWsj
* Date: 2021/8/24
* 定时任务类
*/
@Component
@SuppressWarnings("all")
public class MyTask1 implements SchedulingConfigurer {
@Autowired
private IScheduleSettingService scheduleSettingService;
@Autowired
private CustomerMapper customerMapper;
@Autowired
private RoomMapper roomMapper;
@SneakyThrows
@Override
public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
ScheduleSetting task1Info = scheduleSettingService.getAllById();
//项目部署时,会在这里执行一次,从数据库拿到cron表达式
String cron = task1Info.getCron();
Runnable task = null;
// task1Info.getStatus().toString())转成字符串再比较
// 第一次判断定时逻辑和状态是否正确
// 任务只被创建一次,当cron不为空,并且状态为1的时候才初始化task
if (!StringUtils.isEmpty(cron) && "1".equals(task1Info.getStatus().toString())) {
task = new Runnable() {
@SneakyThrows
@Override
public void run() {
// 任务逻辑代码部分.
// 每天早上9点自动把退房时间为今日12点01分的房间状态改为未入住
// 先找出每天早上12点01分之前住房到期的所有房间
List roomNumList = customerMapper.queryRoomNumEnd(new Date());
roomNumList.stream().forEach(item->{
try {
// 遍历客房id,状态逐个修改为未入住
roomMapper.updateRoomStatusByRoomId((String) item,0);
} catch (Exception e) {
e.printStackTrace();
}
});
}
};
}else {
System.out.println("定时逻辑和状态不正确,任务停止");
return;
}
Trigger trigger = new Trigger() {
@SneakyThrows
@Override
public Date nextExecutionTime(TriggerContext triggerContext) {
//任务触发,可修改任务的执行周期.
//每一次任务触发,都会执行这里的方法一次,重新获取下一次的执行时间
ScheduleSetting newTaskInfo = scheduleSettingService.getAllById();
String newCron = newTaskInfo.getCron();
// 第二次判断定时逻辑和状态是否正确
if (!StringUtils.isEmpty(newCron) && "1".equals(newTaskInfo.getStatus().toString())) {
CronTrigger trigger = new CronTrigger(newCron);
Date nextExec = trigger.nextExecutionTime(triggerContext);
return nextExec;
}else {
System.out.println("定时逻辑和状态不正确,任务停止");
return null;
}
}
};
scheduledTaskRegistrar.addTriggerTask(task, trigger);
}
}
1.2mysql里面存配置: