打卡提醒
时间:20200905
背景
钉钉打卡提醒,只会提醒一次,闹钟也不会周期性提醒,有时候下班想着其他的事情可能先不起来打卡这回事,就可能错过打卡(没有找到钉钉的接口,只能给自己做一个疯狂提醒的应用)
需求
在某个时间段对本人疯狂提醒需要打卡,如果已经打卡,提供接口取消提醒
方案
利用钉钉的推送,在某个时间段一直向钉邮发送邮件,钉钉会一直推送,直到你想起打卡为止
技术选型
- SpringBoot
- springsecurity
- mybatis-plus
实现
1.表设计
只会实现简单的项目,不会做的太复杂,表结构也只需要一张表就够了
CREATE TABLE `punch` (
`id` varchar(60) COLLATE utf8mb4_general_ci NOT NULL COMMENT '主键id',
`punch_status` int(11) DEFAULT NULL COMMENT '1:已打卡,2:未打卡',
`punch_date` varchar(60) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '日期',
`create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
2.核心方法
/**
* 每天 下午六点到晚上十一点 间隔20分钟提醒一次
*/
@Scheduled(cron = "0 0/20 18-23 * * ?")
public void action() {
//获取当前的时间戳
long l = System.currentTimeMillis();
Date date = new Date();
DateFormat dateFormat = new SimpleDateFormat("yyyyMMdd");
String dateStr = dateFormat.format(date);
log.info("查询日期{}",dateStr);
List<Punch> punches = punchService.findByPunchDate(dateStr);
if (CollectionUtils.isNotEmpty(punches)) {
Punch punch = punches.get(0);
if (punch.getPunchStatus().equals(1)) {
log.info("已打卡");
} else {
mailUtils.sendEmailTo("下班了,你还没有打卡\n"+"<a href='punch.pism.com.cn'>punch.pism.com.cn</a>", TO,"打卡提醒");
log.info("未打卡,请打卡");
}
} else {
mailUtils.sendEmailTo("下班了,你还没有打卡\n"+"<a href='punch.pism.com.cn'>punch.pism.com.cn</a>", TO,"打卡提醒");
log.info("未打卡,请打卡");
}
log.info("调度开始,开始时间{}", l);
}
3.源码
缺点
- 只能提醒,还做不到帮忙打卡
- 还没有找到实时获取打卡状态的方案
- 未实现节假日跳过功能
写在最后
- 本项目能简单熟悉SpringBoot 和 springsecurity 以及SpringBoot自带的定时任务操作
- 同事也能简单了解,如何使用java发送邮件
- 希望本项目能帮助到其他人