• 前端JSON请求转换Date问题


    目的:记录使用SpringMVC中前端JSON数据中的日期转换成Date数据类型时区产生的问题
    记录下遇到过的问题
    在使用SpringMVC框架中,使用@RequestBody注解将前端的json数据转换为对应的bean,使用@ResponseBody将bean转换为json(注意:开启该controller层的包扫描)同时使用@JsonFormat,但是没有指定时区,所以导致json中的日期转换成Date类型时,因为时区导致时间不一致。
    使用MySQL数据库,同时没有指定时区导致插入数据库时存在时区问题。

    // VO
    public class FooVO {
        @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone="GMT+8")
        private Date dt;
    }    
    
    // controller
    @Controller
    public class FooController {
        @ResponseBody
        @RequestMapping(value = "/save", method = RequestMethod.POST, consumes = "application/json")
        public ResponseEntity<?> save(@RequestBody FooVO foo) {
            // {"dt":"yyyy-MM-dd HH:mm:ss"} 转换成对应的foo时 如果FooVO.dt字段上的@JsonFormat没有指定时区,则在转换时出现了时区的问题
            return new ResponseEntity<>(HttpStatus.OK);
        }
    }
    
    <!-- 配置jdbc的url时没有指定时区,所以插入Date数据类型时也存在了因时区造成的时间问题 -->
    <!-- jdbc:mysql://ip:port/db?characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai -->
    <insert id="save" parameterType="FooVO">
        insert into foo(dt) values (#{dt})
    </insert>
    
  • 相关阅读:
    9-基础练习 十进制转十六进制
    8-十六进制转十进制
    16-acrobat por 简单使用指南
    LightOJ 1245
    LightOJ 1234
    Codeforces 479【E】div3
    Codeforces 479【F】div3
    Codeforces 479【D】div3
    Codeforces 479【C】div3
    Codeforces 479【B】div3
  • 原文地址:https://www.cnblogs.com/kayj/p/11984215.html
Copyright © 2020-2023  润新知