使用Jackson 处理 null 或者 空字符串

目录
  • Jackson 处理 null 或者 空字符串
    • 这里要区分序列化和反序列化
    • 如果是字段属性级别的
  • jackson解决:null到"", 空值处理为空串
    • 1.一个比较头疼的问题
    • 2.代码如下
    • 3.配置如下

Jackson 处理 null 或者 空字符串

Retrofit 配合 Jackson 反序列化,就是将字符串解析为java bean 对象 的时候 ,如果遇到服务端由于各种原因会导致 有些String类型的字段值为null ,需要替换为空字符串或者占位符“-”什么的,并且不确定 到底会在哪个字段,可以如下处理

这里要区分序列化和反序列化

序列化,就是处理java bean对象转换为字符串,通常设置

objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);

这样在java bean中对象有值为null ,就不会将这个字段或属性序列化为字符串。

或者在java bean 模型定义中注解,表明不将其序列化

@JsonInclude(JsonInclude.Include.NON_NULL)

反序列化,就是将服务器端返回的json串转换为java 对象,通常在处理null值, 将某些值更改为指定格式也类似。可以如下操作

在使用jackson 的时候,通常会通过 compile ‘com.squareup.retrofit2:converter-jackson:2.3.0'集成 官方的 JacksonConverterFactory ,其实它除了自动引入jackson外,另外引入了三个类,可以拷贝出来,方便修改引用,其中只需要更改 JacksonConverterFactory.java 中的create函数即可。针对反序列化过程中String类型处理,添加自定义反序列化器。

public static JacksonConverterFactory create() {
        ObjectMapper objectMapper = new ObjectMapper();
        SimpleModule module = new SimpleModule();
        module.addDeserializer(String.class, new CustomStringDeserializer());
        objectMapper.registerModule(module);
        return create(objectMapper);
    }

其中 CustomStringDeserializer.java 如下 ,重要的就是 getNullValue()的覆写,它决定了如果 反序列化json串中有一个字段的值是 null, 处理策略,这里是默认返回“-”。

public class CustomStringDeserializer extends JsonDeserializer<String> {
    @Override
    public String deserialize(JsonParser jsonparser,
                              DeserializationContext deserializationcontext) throws IOException,
            JsonProcessingException {
        return jsonparser.getText();
    }
    @Override
    public String getNullValue() {
        return "-";
    }
}

这是全局处理情况,如果是类级别的,需要在类上加反序列器,但要处理的就不只是String了,类中所有字段你都需要处理,因为这时,返回的是一个类,

public class CustomClassDeserializer extends JsonDeserializer<T> {
    @Override
    public T deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException {
        return null;
    }
}

然后在类的bean上使用注解,表明该类用这个反序列化器来处理

@JsonDeserialize(using = CustomClassDeserializer.class)
class yourClass()

如果是字段属性级别的

需要在相应的字段属性上这样使用

@JsonDeserialize(using = CustomStringDeserializer.class)
private String name;

还有一种情形是反序列化的时候如果字段是形如“”的空字符串,想转换成null,那就不需要覆写 getNullValue() ,直接在deserialize中处理就好。

jackson解决:null到"", 空值处理为空串

1.一个比较头疼的问题

jackson + spring 支持rest接口,输出的JSON 对于null的字符串是invoiceTitle: null,但是接受方希望返回的是invoiceTitle: ""。解决方法重写ObjectMapper

2.代码如下

public class MyJsonMapper extends ObjectMapper{
  public MyJsonMapper(){
    super();
    this.getSerializerProvider().setNullValueSerializer(new JsonSerializer<Object>() {
      @Override
      public void serialize(Object value, JsonGenerator jg, SerializerProvider sp) throws IOException, JsonProcessingException {
          jg.writeString("");
      }
    });
  }
}

3.配置如下

<bean id="jacksonMapper" class="com.tyky.eduplat.reslib.infrastructure.MyJsonMapper">
<property name="dateFormat">
<bean class="java.text.SimpleDateFormat">
<constructor-arg value="yyyy-MM-dd HH:mm:ss"/>
</bean>
</property>
</bean>
<bean id="jacksonProvider" class="com.fasterxml.jackson.jaxrs.json.JacksonJsonProvider">
<constructor-arg ref="jacksonMapper" />
</bean>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • jackson 实体转json 为NULL或者为空不参加序列化(实例讲解)

    使用jackson进行序列化时,往往会遇到后台某个实体对象的属性为null,当序列化成json时对应的属性也为null:这样在某些前端组件上应用该json对象会报错.(例如:echarts) 下面总结了两种方法,解决了当属性为null时不参与序列化: 方法一: 1.实体上使用如下注解 @JsonInclude(Include.NON_NULL) 将该标记放在属性上,如果该属性为NULL则不参与序列化 :如果放在类上边,那对这个类的全部属性起作用. 具体取值有: //Include.Include

  • 详解Java去除json数据中的null空值问题

    1.描述 @JsonInclude(JsonInclude.Include.NON_NULL)标记是jackson包提供的json序列化方法,已经集成于Springboot2.0中,此方法的配置意在可以对实体json序列化的时候进行对应的数值处理. 2.使用 用注解的方式放在标记类或者属性 @JsonInclude(JsonInclude.Include.NON_NULL) public class User implements Serializable { private String us

  • jackson设置返回null为空字符串的操作

    1.将接口返回的字段为null的设置为空字符串: import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.databind.JsonSerializer; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.SerializerProvider; import org.s

  • springboot项目中jackson-序列化-处理 NULL教程

    在项目中有事需要对值为NULL的对象中Field不做序列化输入配置方式如下: [配置类型]: 源码包中的枚举类: public static enum Include { ALWAYS, NON_NULL, NON_ABSENT, NON_EMPTY, NON_DEFAULT, USE_DEFAULTS; private Include() { } } Include.Include.ALWAYS 默认 Include.NON_DEFAULT 属性为默认值不序列化 Include.NON_EMP

  • 使用Jackson 处理 null 或者 空字符串

    目录 Jackson 处理 null 或者 空字符串 这里要区分序列化和反序列化 如果是字段属性级别的 jackson解决:null到"", 空值处理为空串 1.一个比较头疼的问题 2.代码如下 3.配置如下 Jackson 处理 null 或者 空字符串 Retrofit 配合 Jackson 反序列化,就是将字符串解析为java bean 对象 的时候 ,如果遇到服务端由于各种原因会导致 有些String类型的字段值为null ,需要替换为空字符串或者占位符"-"

  • java json不生成null或者空字符串属性(详解)

    大家平时用java对象转json字符串.null或者空字符串属性是不需要生成到json字符串里面的. 如下方式生成,没有使用的属性也会生成json字符串属性. JSONArray jsonarray = JSONArray.fromObject(ecmMessageMap.values()); msgObj = jsonarray.toString(); {"actionType":"","clientIp":"","

  • java poi 读取单元格null或者空字符串方式

    目录 java poi 读取单元格null或空字符串 java poi读取excel单元格为空的数据,出现空指针异常 产生原因 问题解决 java poi 读取单元格null或空字符串 Cell cell = row.getCell(j, Row.RETURN_BLANK_AS_NULL); 需求 :策划同学填写的单元格有时为null 有时为空串 分条件处理 getcell 可以传入指定的策略 根据需求拿到结果分需处理 java poi读取excel单元格为空的数据,出现空指针异常 空指针异常:

  • js中null与空字符串""的区别讲解

    String str=null 这句话的意思就是定义一个字符串,变量str,字符串的内容为空值. String str="" 定义一个String类型的变量str,并为其赋值. 1.类型 null表示的是一个对象的值,而并不是一个字符串.例如声明一个对象的引用,String a = null ; ""表示的是一个空字符串,也就是说它的长度为0.例如声明一个字符串String str = "" ; 2.内存分配 String str = null

  • 解决mybatis plus字段为null或空字符串无法保存到数据库的问题

    背景 项目中集成了mybatis plus, 今天在做后台的一个常规的增删改查时,发现字段值为null时,这个字段不会被保存到数据库 解决办法 在字段上加上 @TableField(strategy = FieldStrategy.IGNORED) strategy字段更新插入策略属性说明: IGNORED(0): "忽略判断", 所有字段都更新和插入 NOT_NULL(1): "非 NULL 判断", 只更新和插入非NULL值 NOT_EMPTY(2): &quo

  • Oracle数据库中对null值的排序及mull与空字符串的区别

    order by排序之null值处理方法 在对业务数据排序时候,发现有些字段的记录是null值,这时排序便出现了有违我们使用习惯的数据大小顺序问题.在Oracle中规定,在Order by排序时缺省认为null是最大值,所以如果是ASC升序则被排在最后,而DESC降序则排在最前.所以,为何分析数据的直观性方便性,我们需要对null的记录值进行相应处理. 这是四种oracle排序中NULL值处理的方法: 1.使用nvl函数 语法:Nvl(expr1, expr2)     若EXPR1是NULL,

  • 详解MyBatis-Plus updateById方法更新不了空字符串/null解决方法

    最近遇到了Mybatis-Plus updateById(),更新某一个字段为null,却发现没有更新成功,发现有一个博客记录挺好的.转载过来,方便自己看. 一.简介 因为最近在忙项目,好久都没有更新博客,最近在项目中刚好遇到一个问题,就是在使用MyBatis-Plus updateById(xxx)的时候,居然更新不了字符串或者null,本文分享两种解决方案,具体大家可以根据自己的需求选择一种方法解决. 二.原理 在实际项目中,难免更新的时候,有可能会把已有的值更新成空字符串或者null,但是

  • MySQL如何判断字符串为NULL或者为空字符串

    目录 判断字符串为NULL或者为空字符串 MySQL中NULL和空字符串区别 一般会有以下疑问 注意事项 判断字符串为NULL或者为空字符串 函数名 说明 ISNULL(expr) 如果expr为null返回值1,否则返回值为0 IFNULL(expr1,expr2) 如果expr1值为null返回expr2的值,否则返回expr1的值 NULLIF(expr1,expr2) 如果expr1==expr2返回值为null,否则返回expr1的值:相当于case when expr1=expr2

  • mybatis 解决将数值0识别成空字符串的问题

    今天遇到一个问题 我在用java的BigDecimal对象时,值是0.00000:该对象不是空的,是new出来的,我需要将该值插入数据库,数据库对于该值的接收字段类型是decimal. 我使用的Mybatis.mybatis中的语句大致如下: UPDATE user_consumption <trim prefix="SET" suffixOverrides=","> <if test="totalConsumption!=null&qu

随机推荐