开发者

Java日期接收报错:could not be parsed, unparsed text found at index 10解决办法

开发者 https://www.devze.com 2024-01-30 10:17 出处:网络 作者: 一碗情深
目录问题背景代码vueJava实体类Java控制层修改Java控制层解决方法补充:java后端接收前端传递的日期参数为空字符串时报错一、关于接收前端传递的日期参数的问题:二、方案:总结问题背景
目录
  • 问题背景
  • 代码
    • vue
    • Java实体类
    • Java控制层
    • 修改Java控制层
  • 解决方法
    • 补充:java后端接收前端传递的日期参数为空字符串时报错
      • 一、关于接收前端传递的日期参数的问题:
      • 二、方案:
    • 总结

      问题背景

      使用 Element-UI 的 el-date-picker 组件 将日期转给Java,Java报错

      java.time.format.DateTimeParseException: Text ‘2024-01-03T16:00:00.000Z’ could not be parsed, unparsed text found at index 10

      代码

      Vue

      <el-date-picker
        v-model="form.removalDate"
        type="date"
        placeholder="选择日期"
       
      />
      

      Java实体类

      @Data
      @EqualsAndHashCode(callSuper = false)
      @Accessors(chain = true)
      public class AppProjects implements Serializable {
          
          @TableField(updateStrategy = FieldStrategy.IGNORED)
          @jsonFormat(pattern = "yyyy-MM-dd"http://www.devze.com)
          private Date removalDate;
          
      }
      

      Java控制层

      import com.alibaba.fastjson.JSONObject;
      
      public Object update(@RequestBody JSONObject object) {
          AppProjects appProjects = object.toJavaObject(AppProjects.class);
          boolean update = appProjectsService.updateById(appProjects);
          return update;
      }
      

      当执行 toJavaObject 方法时,报错如下

      java.time.format.DateTimeParseException: Text ‘2024-01-03T16:00:00.000Z’ could not be parsed, unparsed text found at index 10

      修改Java控制层

      更改为使用实体类接收参数 @RequestBody AppProjectsphp appProjects

      public Object update(@RequestBody AppProjects appProjects) {
       php   boolean update = appProjectsService.updateById(appProjects);
          return update;
      }
      

      执行方法时不报错,但是日期的值却比实际少一天,为什么呢?

      因为前端实际选择日期为 ‘2024-01-04’ ,传值为 ‘2024-01-03T16:00:00.000Z’,该时区不是东八区,使用实体类接收时去掉了编程时分秒,导致日期保存为 ‘2024-01-03’

      已经不报错了,那么解决日期问题就简单了!

      解决方法

      在 el-date-picker组件 使用属性 value-format="yyyy-MM-dd" 将绑定的格式不指定为 Date 对象,绑定的值会转为 string 对象,那么实际选择哪一天的日期,就是 yyyy-MM-dd 格式的字符串啦!这样后端就能正确接收日期了

      <el-date-picker
        v-model="form.removalDate"
        type="date"
        value-format="yyyy-MM-dd"
        placeholder="选择日期"
       
      />
      

      补充:java后端接收前端传递的日期参数为空字符串时报错

      一、关于接收前端传递的日期参数的问题:

      前提:

      Date类型的属性上添加了以下注解:

      @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd")
      @DateTimeFormat(pattern = "yyyy-MM-dd")
      @JSONField(format = "yyyy-MM-dd")
      

      1、java.sql.date:空字符串解析报错,正常日期格式字符串没问题;

      2、java.util.date:空字符串解析没问题,正常日期格式字符串用于查询时报错;js

      二、方案:

      1、Controller层添加以下方法,自定义解析参数(只在该Controller层生效)

      @InitBinder
          public void initBinder(WebDataBinder binder){
              SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
              // spring提供的日期解析器(格式化,是否允许为空)选择true则将空字符串解析为null
              CustomDateEditor customDateEditor = new CustomDateEditor(simpleDateFormat, true);
              // 为Date类型的属性注册解析器
              binder.registerCustomEditor(Date.class, customDateEditor);
          }
      

      2、java.util.date用于查询时格式化为yyyy-MM-dd

      3、前端传递正确的日期/不传递该参数

      总结

      到此这篇关于Java日期接收报错:could not be parsed, unparsed text found at index 10解决办法的文章就介绍到这了,更多相关Java日期接收报错could not be parsed内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

      0

      精彩评论

      暂无评论...
      验证码 换一张
      取 消