软件开发定制解决JSON中文乱码以及JSON处理Date格式

软件开发定制项目启动保错(jackson软件开发定制版本问题导致项目启动失败)




软件开发定制出现这个错误是因为jackson依赖和springboot软件开发定制依赖版本有冲突,把jsckson软件开发定制的依赖版本从2.9.8换成 2.11.0即可

9. JSON中文乱码

软件开发定制如果出现乱码,软件开发定制我们需要设置他的为utf-8,以及它返回的类型,通过@RequesMapping的produces属性来实现,代码如下

:指定响应体返回类型和编码

@RequestMapping(value = "/json1",produces ="application/json;charset=utf-8")
  • 1
  • 2

JSON处理Date格式

@RequestMapping(value = "/date1")@ResponseBodypublic String date1() throws JsonProcessingException {    //声明时间日期 注意是util下的    Date date = new Date();    //打印默认时间日期格式  Tue Feb 08 21:36:27 CST 2022    System.out.println(date);    //发现问题  时间默认返回的json字符串变成了时间戳类型的格式 Timestamp 1644327387386    return   new ObjectMapper().writeValueAsString(date);}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

发现问题:时间默认返回的json字符串变成了时间戳类型的格式 Timestamp 1644327387386
处理问题:如何让它不返回时间戳?如何时间格式化问题

 //关闭ObjectMapper的时间戳功能 通过objectMapper的configure方法关闭时间戳功能  ObjectMapper objectMapper=new ObjectMapper();  objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,false);  SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");   objectMapper.setDateFormat(simpleDateFormat);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
@RequestMapping(value = "/date2")@ResponseBodypublic String date2() throws JsonProcessingException {    //1 如何让它不返回时间戳?   通过objectMapper的configure方法关闭时间戳功能    ObjectMapper objectMapper=new ObjectMapper();    objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,false);    //2 时间格式化问题 自定义日期格式对象    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");    //3 让objectMapper指定日期格式为simpleDateFormat    objectMapper.setDateFormat(simpleDateFormat);    //声明Date    Date date = new Date();    //格式化日期并输出    System.out.println(simpleDateFormat.format(date));//2022-02-08 22:01:12    return   objectMapper.writeValueAsString(date);//"2022-02-08 22:01:12"}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

封装JSON工具日期转化工具类

上述代码冗余 我们把公共代码提取出来进行封装成工具类,下次使用直接调用即可
工具类和公共方法

package com.wyh.util;import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jackson.databind.ObjectMapper;import com.fasterxml.jackson.databind.SerializationFeature;import java.util.Date;import java.text.SimpleDateFormat;/** * @program: SpringBoot-Ajax-JSON * @description: JSON日期格式化封装类 * @author: 魏一鹤 * @createDate: 2022-02-08 22:07 **/public class JSONDateUtil {    //重载 把时间戳也进行封装    //如果没有自定义时间格式的话就使用我们默认的yyyy-MM-dd HH:mm:ss"      //如果调用方法在参数列表指明了自定义时间格式的话就使用参数列表的时间格式    public static String JSONFormatDateUtil(Object object){        return JSONFormatDateUtil(object,"yyyy-MM-dd HH:mm:ss");    }    // JSON转换日期的公共方法,直接传递Date类型的参数使用ObjectMapper进行处理 需要抛出异常 得到格式化好之后的json日期类型    // 把方法用static进行修饰是为了不用创建工具类对象就能直接通过“.”进行公共方法的调用    public static String JSONFormatDateUtil(Object object,String dateFormat){        //1 创建ObjectMapper工具类        ObjectMapper objectMapper=new ObjectMapper();        //2 通过ObjectMapper类的configure方法关闭时间戳功能        objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,false);        //3 创建时间格式化SimpleDateFormat类 自定义日期格式对象        SimpleDateFormat simpleDateFormat = new SimpleDateFormat(dateFormat);        //4 把自定义格式化好之后的日期类型给objectMapper的setDateFormat去用,用来转换时间格式        objectMapper.setDateFormat(simpleDateFormat);        //5 json转换时间格式得到json字符串日期类型        //封装的时候尽量不要抛异常而是捕获异常 不然每次调用这个方法都要在其他地方进行抛异常        String JSONDate = null;        try {            JSONDate = objectMapper.writeValueAsString(object);        } catch (JsonProcessingException e) {            e.printStackTrace();        }        //6 返回最终处理好的json字符串日期类型        return JSONDate;    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49

使用工具类和公共方法
注意观察JSONDateUtil.JSONFormatDateUtil()的参数列表和返回的格式

   //使用工具类和公共方法    @RequestMapping(value = "/date3")    @ResponseBody    public String date3()  {        //声明Date        Date date = new Date();        //使用工具类的公共方法把date进行传参转换格式        String JSONDate = JSONDateUtil.JSONFormatDateUtil(date);        //返回json日期类型        return  JSONDate; //"2022-02-08 22:31:11"    }}//使用工具类@RequestMapping(value = "/date3")@ResponseBodypublic String date3()  {    //声明Date    Date date = new Date();    //使用工具类的公共方法把date进行传参转换格式    String JSONDate = JSONDateUtil.JSONFormatDateUtil(date,"yyyy");     //返回json日期类型    return  JSONDate; //"2022"}//使用工具类@RequestMapping(value = "/date3")@ResponseBodypublic String date3()  {    //声明Date    Date date = new Date();    //使用工具类的公共方法把date进行传参转换格式    String JSONDate = JSONDateUtil.JSONFormatDateUtil(date,"yyyy-MM-dd");    //返回json日期类型    return  JSONDate;  //"2022-02-08"}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
网站建设定制开发 软件系统开发定制 定制软件开发 软件开发定制 定制app开发 app开发定制 app开发定制公司 电商商城定制开发 定制小程序开发 定制开发小程序 客户管理系统开发定制 定制网站 定制开发 crm开发定制 开发公司 小程序开发定制 定制软件 收款定制开发 企业网站定制开发 定制化开发 android系统定制开发 定制小程序开发费用 定制设计 专注app软件定制开发 软件开发定制定制 知名网站建设定制 软件定制开发供应商 应用系统定制开发 软件系统定制开发 企业管理系统定制开发 系统定制开发