java8中的时间类LocalDate、LocalTime、LocalDateTime使用总结

简介: java8中新的日期类LocalDate、LocalDateTime使用总结

java8中新的时间类LocalDate、LocalTime、LocalDateTime在进行前后端交互和数据持久化时会遇到格式问题和映射问题,总结如下:
1、使用springboot jpa时报错:数据库操作失败,提示【could not deserialize】(无法反序列化)
解决方法:pom文件引入下面的jar包

<dependency>
    <groupId>org.hibernate</groupId>
    <artifactId>hibernate-java8</artifactId>
    <version>5.1.2.Final</version>
 </dependency>

2、上面jar包引入后就没再报错,但前端时间字段显示格式不是我们常见的“yyyy-MM-dd hh:mm:ss”,而是下面的样子:

"createTime": {
    "month": "DECEMBER",
    "year": 2018,
    "dayOfMonth": 12,
    "dayOfWeek": "WEDNESDAY",
    "dayOfYear": 346,
    "monthValue": 12,
    "hour": 10,
    "minute": 22,
    "nano": 0,
    "second": 25,
    "chronology": {
        "id": "ISO",
        "calendarType": "iso8601"
}

解决方法:
引入下面的jar包

<dependency>
    <groupId>com.fasterxml.jackson.datatype</groupId>
    <artifactId>jackson-datatype-jsr310</artifactId>
    <version>2.8.5</version>
</dependency>

同时在类的时间字段上加上注解:@JsonFormat(pattern = "yyyy-MM-dd hh:mm:ss")

@JsonFormat(pattern = "yyyy-MM-dd hh:mm:ss")
 private LocalDateTime createTime;
@JsonFormat(pattern = "yyyy-MM-dd hh:mm:ss")
private LocalDateTime updateTime;

现在再看一下返回结果

"createTime": "2018-12-11 06:41:33",
"updateTime": "2018-12-11 06:41:33",

格式完全正确了
3、虽然格式现在已经正确了,但是还有一个小问题:返回结果是12小时制,数据库中是24小时制,一般我们也是用24小时制
screenshot
解决方法:
在@JsonFormat注解中pattern = "yyyy-MM-dd HH:mm:ss",就是把小写的hh换成HH就可以了

   @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private LocalDateTime createTime;
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private LocalDateTime updateTime;

返回结果如下:

"createTime": "2018-12-11 18:41:33",
"updateTime": "2018-12-11 18:41:33",

完美解决。
4、我是用的持久化框架是JPA JPA包装的是hibernate,所以第一步用的是hibernate-java8,如果是mybatis的话,请引入下面的jar包

<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-typehandlers-jsr310</artifactId>
    <version>1.0.2</version>
</dependency>

5、实际设计中,create_time和update_time这俩字段一般是数据库自动生成,这个时候如果使用JPA的话,需要在相应属性加上注解:@Column(insertable = false, updatable = false)。如下所示:

    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    @Column(insertable = false, updatable = false)
    private LocalDateTime createTime;
    /**更新时间*/
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    @Column(insertable = false, updatable = false)
    private LocalDateTime updateTime;

这样的话我们子新增和更新表数据的时候,这两个字段会使用数据库自动生成和更新。

6、前端在RequestBody中传时间参数,后端用LocalDate、LocalTime、LocalDateTime来接收的话,直接在字段上使用@JsonFormat注解,如下面的operateTime字段。

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

注意前端传的数据一定要严格符合pattern中指定的格式,如果前端传"2019-02-13",而pattern中的格式为"yyyy-MM-dd HH:mm:ss"的话,也会报错,不能自动转成"2019-02-13 00:00:00"。
7、前端在RequestParam和PathVariable中传时间参数的话,上面的方法就不好使了,这时候需要加一个日期转换器,使用Spring中的Converter来实现

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.convert.converter.Converter;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

@Configuration
public class DateConfig {

    @Bean
    public Converter<String, LocalDate> localDateConverter() {
        return new Converter<String, LocalDate>() {
            @Override
            public LocalDate convert(String source) {
                return LocalDate.parse(source, DateTimeFormatter.ofPattern("yyyy-MM-dd"));
            }
        };
    }

    @Bean
    public Converter<String, LocalDateTime> localDateTimeConverter() {
        return new Converter<String, LocalDateTime>() {
            @Override
            public LocalDateTime convert(String source) {
                return LocalDateTime.parse(source, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
            }
        };
    }
}

把上面代码加入到项目中就可以。

相关文章
|
15天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
37 17
|
6天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
11天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
50 4
|
11天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
27 2
|
16天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
3月前
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
58 7
|
23天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
16 3
|
23天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
28 2
|
23天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
28 1
|
3月前
|
Oracle 安全 Java
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的
JDK8到JDK28版本升级的新特性问题之在Java 15及以后的版本中,密封类和密封接口是怎么工作的