Controller层
public AjaxResult export(@RequestBody IncomingAccountQuery incomingAccountQuery)
{
//判断时间是否大于90天
HashMap<String, Object> timeMap = new HashMap<>();
@NotBlank String beginTime = incomingAccountQuery.getStartTime();
@NotBlank String endTime = incomingAccountQuery.getEndTime();
timeMap.put("beginTime",beginTime);
timeMap.put("endTime",endTime);
boolean isValid = businessDaytransDataService.isValidSearchTimeNinety(timeMap, false);
if (!isValid)
{
return AjaxResult.error("开始时间结束时间参数不能为空,时间间隔不能超过90天!");
}
}
可以看到 ,开始时间和结束时间是前端传递的,我们拿到这两个参数,放进map里,调用了一个
isValidSearchTimeNinety(timeMap, false)的方法,我们来看看这个方法里做了什么
接口
/**
* 判断搜索时间 是否有效 前后时间间隔不超过90天
* @param map
* @return
*/
boolean isValidSearchTimeNinety(Map<String, Object> map,boolean isNeedAddOneEndDay);
实现类
@Override
public boolean isValidSearchTimeNinety(Map<String, Object> map, boolean isNeedAddOneEndDay)
{
Object beginTime = map.get("beginTime");
Object endTime = map.get("endTime");
if (beginTime == null || endTime == null)
{
return false;
}
String beginTimeStr = beginTime.toString();
String endTimeStr = endTime.toString();
if (beginTimeStr.isEmpty() || endTimeStr.isEmpty())
{
return false;
}
long days = DateUtil.between(DateUtil.parseDate(beginTimeStr), DateUtil.parseDate(endTimeStr), DateUnit.DAY);
if (days > 90)
{
return false;
}
map.put("initEndTime", endTime.toString());
//判断结束日期是否需要加一天 存在页面上查询带时分秒格式的日期 传入同一天 结束日期需要加一天的情况
if (isNeedAddOneEndDay)
{
DateTime d = DateUtil.offsetDay(DateUtil.parseDate(endTimeStr), 1);
map.replace("endTime", d.toDateStr());
}
return true;
}
可以看到,实现类里这段代码,实现了对传入时间是否大于90天做了一个校验
long days = DateUtil.between(DateUtil.parseDate(beginTimeStr), DateUtil.parseDate(endTimeStr), DateUnit.DAY);
if (days > 90)
{
return false;
}
那么如果你有这种对时间参数规定对大的一个需求。完全可以拿我的接口 和实现类,进行修改!!
本文介绍了一种用于验证前端传入的时间参数是否超出90天间隔的方法。通过Controller层调用业务逻辑层的方法,利用DateUtil工具类计算两个时间点之间的天数差,确保其不超过90天。
1959

被折叠的 条评论
为什么被折叠?



