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;

 

你可能感兴趣的:(springboot,JPA,MySQL,java)