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 map = new HashMap<>();try {if(pageNo==null||size==null||pageNo==0||size==0){return Result.fail(903,"pageNo和size不能为空或者等于0");}Page pager = driverService.getDao().findDriverPage(PageRequest.of(pageNo, size),agentName,lineName,driverName,driverSfzh,driverPhone);map.put("rows", pager.getTotalElements());//查询到的总记录数map.put("pages", pager.getTotalPages());//查询到的总页数map.put("page", pageNo);List> datas = new ArrayList<>();pager.forEach(driver -> {Map item = new HashMap<>();item.put("id",driver.getId());item.put("zgzEndDate",driver.getZgzEndDate()!=null?dateToString(driver.getZgzEndDate(),"yyyy-MM-dd"):"");item.put("createTime",driver.getCreateTime()!=null?dateToString(driver.getCreateTime(),"yyyy-MM-dd HH:mm:ss"):"");datas.add(item);});map.put("datas",datas);return Result.ok(map);}catch (Exception e){e.printStackTrace();return Result.fail(901,"获取列表失败");}
}

首先让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;

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部