使用@JsonFormat和@DateTimeFormat对Date格式化

使用@JsonFormat和@DateTimeFormat对Date格式化

实体类

package com.pojo;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
    
public class User {
     private Long id;
     private String username;//用户名
     private String password;//密码
     private String phone;//手机号
     private String email;//邮箱
     private Date created;//创建日期
     private Date updated;//修改日期
 
     public Long getId() { return id; }
     public void setId(Long id) { this.id = id;}
 
     public String getUsername() {return username;}
     public void setUsername(String username) {this.username = username;}
 
     public String getPassword() { return password;}
     public void setPassword(String password) { this.password = password;}
 
     public String getPhone() { return phone;}
     public void setPhone(String phone) {this.phone = phone;}
 
     public String getEmail() {return email;}
     public void setEmail(String email) { this.email = email;}
 
     public Date getCreated() {return created;}
     public void setCreated(Date created) {this.created = created;}
    
     public Date getUpdated() {return updated;}
     public void setUpdated(Date updated) {this.updated = updated;}
 }

一、@JsonFormat

控制器:

     @RequestMapping("/getdate")
	@ResponseBody
	public TbUser getdate() {
		TbUser user = new TbUser();
		user.setId(1001l);
		user.setUsername("zhangsan");
		user.setPassword("1234567");
		user.setPhone("15225969681");
		user.setEmail("123@qq.com");
		user.setUpdated(new Date());
		user.setCreated(new Date());
		return user;
	}

访问控制器在浏览器中输出的json格式如下:

{"id":1001,"username":"zhangsan","password":"1234567","phone":"15212559252","email":"123@qq.com","created":1545288773904,"updated":"1545288773904"}

可见created、updated这两个属性值是时间戳并不是“yyyy-MM-dd HH:mm:ss”格式,那怎么把日期类型格式化成我们想要的类型呢,其实很简单只需要在实体类的属性上加上**@JsonFormat**注解就行了。

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

@JsonFormat(pattern=“yyyy-MM-dd”,timezone = “GMT+8”)
**pattern:**是你需要转换的时间日期的格式
**timezone:**是时间设置为东八区(北京时间)
提示:@JsonFormat注解可以在属性的上方,同样可以在属性对应的get方法上,两种方式没有区别。

再次访问控制器,会发现在浏览器中输出的json格式就会变成我们指定的时间格式了。如下:

{"id":1001,"username":"zhangsan","password":"1234567","phone":"15225969681","email":"123@qq.com","created":2018-12-19 19:00:11,"updated":"2018-12-19 19:00:11"}

加上注解后将User对象转为json字符串时也是会按照注解中的格式进行转换

二、@DateTimeFormat

Index.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>测试</title>
</head>
<body>
	<form method="post" action="/getuser">
		用户名:<input type="text" name="username"/></br>
		密码:<input type="password" name="password"/></br>
		手机:<input type="text" name="phone"/></br>
		邮箱:<input type="text" name="email"/></br>
		创建日期:<input type="datetime" name="created"/></br>
		修改日期:<input type="datetime" name="updated"/></br>
		<input type="submit" />
	</form>
</body>
</html>
@RequestMapping(value="/getuser", method=RequestMethod.POST)
@ResponseBody
public TbUser getuser(TbUser user) {
	System.out.println("-------------------------------");
	System.out.println(user.toString());
	System.out.println("-------------------------------");
	return user;
}

在这里插入图片描述

当User实体类created、updated不加注解 @DateTimeFormat(pattern = “yyyy-MM-dd”) 时可以输入任意格式的日期如yyyy-MM-dd、yyyy/MM/dd…,后台仍会将接收到的字符串转换为Date,但如果加上@DateTimeFormat注解就只能按照注解后面的日期格式进行输入了。

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

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

控制台输出结果如下:

User [id=null, username=test, password=123, phone=12345678901, email=12112@qq.com, created=Thu Dec 20 00:00:00 CST 2012, updated=Thu Dec 20 00:00:00 CST 2012]

总结:
注解**@JsonFormat**:主要是控制后台到前台的时间格式
注解**@DateTimeFormat**:主要是限制前台到后台的时间格式


顺便分享一个json和Object互转的工具类,源码如下:

package com.common.utils;
import java.util.List;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.ObjectMapper;

public class JsonUtils {
    // 定义jackson对象
    private static final ObjectMapper MAPPER = new ObjectMapper();
    /**
     * 将对象转换成json字符串。
     * <p>Title: pojoToJson</p>
     * <p>Description: </p>
     * @param data
     * @return
     */
    public static String objectToJson(Object data) {
    	try {
			String string = MAPPER.writeValueAsString(data);
			return string;
		} catch (JsonProcessingException e) {
			e.printStackTrace();
		}
    	return null;
    }
    
    /**
     * 将json结果集转化为对象
     * 
     * @param jsonData json数据
     * @param clazz 对象中的object类型
     * @return
     */
    public static <T> T jsonToPojo(String jsonData, Class<T> beanType) {
        try {
            T t = MAPPER.readValue(jsonData, beanType);
            return t;
        } catch (Exception e) {
        	e.printStackTrace();
        }
        return null;
    }
    
    /**
     * 将json数据转换成pojo对象list
     * <p>Title: jsonToList</p>
     * <p>Description: </p>
     * @param jsonData
     * @param beanType
     * @return
     */
    public static <T>List<T> jsonToList(String jsonData, Class<T> beanType) {
    	JavaType javaType = MAPPER.getTypeFactory().constructParametricType(List.class, beanType);
    	try {
    		List<T> list = MAPPER.readValue(jsonData, javaType);
    		return list;
		} catch (Exception e) {
			e.printStackTrace();
		}
    	return null;
    }
}
@jsonformat和@datetimeformat是两个常用的注解,用于在Java应用程序中格式化日期和时间。 @jsonformat注解用于在对象的属性上指定日期和时间的格式,以便在将对象转换为JSON字符串时使用。例如,我们可以使用以下方式在对象的属性上使用@jsonformat注解来指定日期的格式: ```java public class User { private String name; @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date birthDate; // getters and setters } ``` 在上面的例子中,@JsonFormat注解指定了birthDate属性的日期格式为"yyyy-MM-dd HH:mm:ss"。当将User对象转换为JSON字符串时,birthDate属性的值将按照指定的格式进行格式化。 @datetimeformat注解用于在Spring框架中控制器方法参数或返回值上指定日期和时间的格式。它可以用于将请求参数的字符串解析为日期对象,或者将日期对象格式化为响应体中的字符串。例如,我们可以使用以下方式在控制器方法参数上使用@datetimeformat注解来指定日期的格式: ```java @GetMapping("/users") public String getUser(@DateTimeFormat(pattern = "yyyy-MM-dd") Date birthDate) { // 处理逻辑 } ``` 在上面的例子中,@DateTimeFormat注解指定了birthDate参数的日期格式为"yyyy-MM-dd"。当请求到达该控制器方法时,会将请求参数中的字符串解析为指定格式的日期对象。 总的来说,@jsonformat和@datetimeformat注解都是用于在Java应用程序中格式化日期和时间,但用途略有不同。@jsonformat注解用于将对象转换为JSON字符串时指定日期格式,而@datetimeformat注解用于在Spring框架中控制器方法参数或返回值上指定日期格式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值