注解篇:@DateTimeFormat和@JsonFormat

码海绘汐使
• 阅读 7134

@JsonFormat和@DateTimeFormat注解的使用


>背景:

从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时 间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个 问题,我们通过使用@JsonFormat可以很好的解决:后台到前台时间格式保持一致的问题。

其次,另一个问题是,我们在使用Web服务的时,可能会需要用到,传入时间给后台,比如注册新用户需要填入出生日期等,这个时候前台传递给后台的时间格式同样是不一致的,而我们的与之对应的便有了另一个注解,@DataTimeFormat便很好的解决了这个问题。

接下来记录一下具体的@JsonFormat与DateTimeFormat的使用过程。


1.注解@JsonFormat


1.1.使用maven引入@JsonFormat所需要的jar包,我贴一下我这里的pom文件的依赖。
<!--JsonFormat-->

 <dependency>
 <groupId>com.fasterxml.jackson.core</groupId>
 <artifactId>jackson-annotations</artifactId>
 <version>2.8.8</version>
 </dependency>

 <dependency>
 <groupId>com.fasterxml.jackson.core</groupId>
 <artifactId>jackson-databind</artifactId>
 <version>2.8.8</version>
 </dependency>

 <dependency>
 <groupId>org.codehaus.jackson</groupId>
 <artifactId>jackson-mapper-asl</artifactId>
 <version>1.9.13</version>
 </dependency>

1.2.在你需要查询出来的时间的数据库字段对应的实体类的属性上添加@JsonFormat


import java.util.Date;

import com.fasterxml.jackson.annotation.JsonFormat;

public  class  TestClass {

//设置时区为上海时区,时间格式自己据需求定。

@JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")

    private Date testTime;

public Date gettestTime() {

    return testTime;
 }
 
public void settestTime(Date testTimee) {

     this.testTime= testTime;

 }

}

这里解释一下:@JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")

   pattern:是你需要转换的时间日期的格式

   timezone:是时间设置为东八区,避免时间在转换中有误差

提示:@JsonFormat注解可以在属性的上方,同样可以在属性对应的get方法上,两种方式没有区别。

1.3.完成上面两步之后,我们用对应的实体类来接收数据库查询出来的结果时就完成了时间格式的转换,再返回给前端时就是一个符合我们设置的时间格式了


2.注解@DateTimeFormat


介绍:
2.1 java.util.Date、java.util.Calendar、java.long.Long 时间类型进行标注:

**– pattern 属性:类型为字符串。指定解析/格式化字段数据的模式,
如:**

yyyy-MM-dd hh:mm:ss
iso 属性:类型为 DateTimeFormat.ISO。指定解析/格式化字段数据的ISO模式.

包括四种:

  • ISO.NONE(不使用)

指示不应应用基于ISO的格式模式

  • 默认ISO.DATE(yyyy-MM-dd)

最常见的ISO日期格式yyyy-MM-dd,例如 " 2020-9-17 " 。

  • ISO.TIME(hh:mm:ss.SSSZ)

最常见的ISO时间格式HH:mm:ss.SSSXXX,例如“ 01:30:00.000-05:00”。

  • ISO.DATE_TIME(yyyy-MM-dd hh:mm:ss.SSSZ)

最常见的ISO日期时间格式yyyy-MM-dd'T'HH:mm:ss.SSSXXX,例如“ 2000-10-31T01:30:00.000-05:00”。

**– style 属性:字符串类型。
通过样式指定日期时间的格式,由两位字符组成**

  • 第一位表示日期的格式
  • 第二位表示时间的格式
  • S:短日期/时间格式
  • M:中日期/时间格式
  • L:长日期/时间格式
  • F:完整日期/时间格式
  • -:忽略日期或时间格式
    • *
3.注解@DateTimeFormat的使用

3.1 @DateTimeFormat的使用和@jsonFormat差不多,首先需要引入是spring还有jodatime,spring我就不贴了.

<!-- joda-time -->

 <dependency>
    <groupId>joda-time</groupId>
     <artifactId>joda-time</artifactId>
     <version>2.3</version>
 </dependency>

3.2 在controller层我们使用spring mvc 表单自动封装映射对象时,我们在对应的接收前台数据的对象的属性上加@DateTimeFormat

@DateTimeFormat(pattern = "yyyy-MM-dd")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date startTime;
     
@DateTimeFormat(pattern = "yyyy-MM-dd")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date endTime;

我这里就只贴这两个属性了,这里我两个注解都同时使用了,因为我既需要取数据到前台,也需要前台数据传到后台,都需要进行时间格式的转换,可以同时使用.


3.3 通过上面两个步骤之后,我们就可以获取一个符合自定义格式的时间格式存储到数据库了.


总结:

## 注解@JsonForma:

主要是后台到前台的时间格式的转换

**JsonFormat :出参
@JsonFormat(pattern=”yyyy-MM-dd”) 将Date转换成String 一般后台传值给前台时
如:@JsonFormat(timezone = “GMT+8”, pattern = “yyyy-MM-dd HH:mm”)**

注解@DataFormat:

主要是前后到后台的时间格式的转换

**DateTimeFormate :入参
@DatetimeFormat是将String转换成Date,一般前台给后台传值时用
如:@DateTimeFormat(pattern = “yyyy-MM-dd HH:mm”)**

点赞
收藏
评论区
推荐文章
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Karen110 Karen110
4年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
Java日期时间API系列31
  时间戳是指格林威治时间1970年01月01日00时00分00秒起至现在的总毫秒数,是所有时间的基础,其他时间可以通过时间戳转换得到。Java中本来已经有相关获取时间戳的方法,Java8后增加新的类Instant等专用于处理时间戳问题。 1获取时间戳的方法和性能对比1.1获取时间戳方法Java8以前
皕杰报表(关于日期时间时分秒显示不出来)
在使用皕杰报表设计器时,数据据里面是日期型,但当你web预览时候,发现有日期时间类型的数据时分秒显示不出来,只有年月日能显示出来,时分秒显示为0:00:00。1.可以使用tochar解决,数据集用selecttochar(flowdate,"yyyyMMddHH:mm:ss")fromtablename2.也可以把数据库日期类型date改成timestamp
Karen110 Karen110
4年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Stella981 Stella981
3年前
Django之Django模板
1、问:html页面从数据库中读出DateTimeField字段时,显示的时间格式和数据库中存放的格式不一致,比如数据库字段内容为2012082616:00:00,但是页面显示的却是Aug.26,2012,4p.m.答:为了页面和数据库中显示一致,需要在页面格式化时间,需要添加<td{{dayrecord.p\_time|date:
Wesley13 Wesley13
3年前
mysql中时间比较的实现
MySql中时间比较的实现unix\_timestamp()unix\_timestamp函数可以接受一个参数,也可以不使用参数。它的返回值是一个无符号的整数。不使用参数,它返回自1970年1月1日0时0分0秒到现在所经过的秒数,如果使用参数,参数的类型为时间类型或者时间类型的字符串表示,则是从1970010100:00:0
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Easter79 Easter79
3年前
Swagger如何测试Date类型参数
问题Swagger测试时,参数直接输入日期格式化后的类型,会报参数日期转换错误:ConversionFailedException解决网上说在参数上添加注解@DateTimeFormat(pattern“yyyyMMdd”)或者是添加@JsonFormat(pattern”yyyyMMddHH:mm:
Stella981 Stella981
3年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Wesley13 Wesley13
3年前
Java日期时间API系列23
  有时候,往往需要统计某个时间区间的销量等问题,这就需要准确的起始时间,获取准确开始时间00:00:00,获取准确结束时间23:59:59。下面增加了一一些方法,获取当天起始时间,昨天起始时间,当前月第一天开始时间,当前月最后一天结束时间,上个月第一天开始时间,上个月最后一天结束时间,某个指定月的起始结束时间等等。其中月份最后一天往往因为月份不同和