@JsonFormat与@DateTimeFormat注解的使用

背景:从数据库获取时间传到前端进行展现的时候,咱们有时候可能没法获得一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个问题,咱们经过使用@JsonFormat能够很好的解决:后台到前台时间格式保持一致的问题,其次,另外一个问题是,咱们在使用WEB服务的时,可能会须要用到,传入时间给后台,好比注册新用户须要填入出生日期等,这个时候前台传递给后台的时间格式一样是不一致的,而咱们的与之对应的便有了另外一个注解,@DataTimeFormat便很好的解决了这个问题,接下来记录一下具体的@JsonFormat与DateTimeFormat的使用过程。前端

声明:关于@JsonFormat的使用,必定要导入正确完整的包。java

1.注解@JsonFormat

  1.使用maven引入@JsonFormat所须要的jar包,我贴一下我这里的pom文件的依赖spring

<!--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>

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")json

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

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

  提示:@JsonFormat注解能够在属性的上方,一样能够在属性对应的get方法上,两种方式没有区别maven

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

2.注解@DateTimeFormat

1.@DateTimeFormat的使用和@jsonFormat差很少,首先须要引入是spring还有jodatime,spring我就不贴了spa

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

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

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

我这里就只贴这两个属性了,这里我两个注解都同时使用了,由于我既须要取数据到前台,也须要前台数据传到后台,都须要进行时间格式的转换,能够同时使用

3.经过上面两个步骤以后,咱们就能够获取一个符合自定义格式的时间格式存储到数据库了

总结: 

  注解@JsonFormat主要是后台到前台的时间格式的转换

  注解@DataFormAT主要是先后到后台的时间格式的转换

相关文章
相关标签/搜索