SSM框架前后台日期处理问题

在次之前我先声明一下我在这里遇到的一个大坑:就是时区的问题,所有条件,都能在控制台看出来,前后台也不报错的情况下,那么就证明你的代码没有问题,问题出在时区的那块!

我的这次时区问题,是因为数据版本导致的,5点几的一般不会出现,就是因为版本原因导致的时区不同,我的环境是mysql8.0+连接器8.0,之前设置的是UTC时区,改完后设置成Asia/Shanghai就完美解决!

这块我整理一下关于时间的一些配置:

我的dao、mapper、vo是通过mybatis逆向工程生成的,标红的是针对生成query文件里的函数说的

一、jsp页面对于日期格式的显示和传值

<input name="orderdate"  type="date" value="<fmt:formatDate value="${orderdate}"  pattern="yyyy-MM-dd" type="date"/>"/>

二、运行框架后出现日期不能为空的错误

        在controller里面加上这一条,表示在当前类里不会出现问题

@InitBinder
public void init(WebDataBinder binder) {
    binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"), true));
}

     但是这里注意,日期类型的数据没有模糊查询,所以参数传进andOrderflagEqualTo()里必须不能是null值,所以用次函数之前需要判断一下后台传过来的日期是否为空

if(bz.getOrderdate()!=null){
    criteria.andOrderdateEqualTo(bz.getOrderdate());
}

三、时间格式处理注解

        @DateTimeFormat(pattern = "yyyy-MM-dd"):该注解放在实体类里的属性上面,

        @@JsonFormat(pattern = "yyyy-MM-dd",timezone = "UTC"):该注解加在实体类中的日期类型上,可以将返回的Json字符串中的时间戳转换为具体时间

     使用原因:

     从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个问题,我们通过使用@JsonFormat可以很好的解决:后台到前台时间格式保持一致的问题,其次,另一个问题是,我们在使用WEB服务的时,可能会需要用到,传入时间给后台,比如注册新用户需要填入出生日期等,这个时候前台传递给后台的时间格式同样是不一致的,而我们的与之对应的便有了另一个注解,@DataTimeFormat便很好的解决了这个问题,

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值