spring boot+jpa+MySQL格式化返回数据中实体对象对应的日期格式
在controller中设置返回参数中的日期格式有三种:
1.在配置文件application.yml中设置整个项目关于日期的格式:
| spring: jackson: time-zone: GMT+8 date-format: yyyy-MM-dd |
这样设置后,项目中所有关于日期的参数除非特定设置,都会按照yyyy-MM-dd格式返回
2.在controller中设置返回参数的格式:
public static String dateToString(Date date, String dateFrom){String time = null;try {SimpleDateFormat sdf = new SimpleDateFormat(dateFrom);time = sdf.format(date);}catch (Exception e){e.printStackTrace();}return time;
}
@PostMapping("/api/driver/list")
public Result driverList(Integer pageNo, Integer size, String agentName, String lineName, String driverName, String driverSfzh, String driverPhone){Map |
首先让controller继承基础controller类,然后就可以用基础controller类中的dateToString方法格式化时间,然后在设置返回参数是日期时,调用dateToString方法格式化日期,这样返回的日期也是格式化后的。
3.在实体类中的日期属性上加上注解@JsonFormat(shape= JsonFormat.Shape.STRING,pattern="yyyy-MM-dd",timezone="GMT+8"),这样返回这个实体类对应的日期参数时也是格式化的,而且是yyyy-MM-dd格式的,不受方法一设置的影响。
import com.fasterxml.jackson.annotation.JsonFormat; @DateTimeFormat(pattern = "yyyy-MM-dd")//设置接收日期参数时的格式 @JsonFormat(shape= JsonFormat.Shape.STRING,pattern="yyyy-MM-dd",timezone="GMT+8")//设置返回日期参数时的格式 @Column(name = "start_date",columnDefinition = " DATE COMMENT '票价生效开始时间'") private Date startDate; |
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
