使用JSON.toJSONString格式化成json字符串时保留null属性

使用JSON.toJSONString格式化成json字符串时保留null属性

目录

JSON.toJSONString格式化成json字符串时保留null属性

使用阿里的

com.alibaba.fastjson.JSON

格式化时,默认null属性会被过滤掉,可以设置不过滤null

public static String parseScriptJsonStringWithNullValue(Object obj) { 
   if (obj == null || (obj instanceof Undefined)) { 
      return null; 
   } 
   return JSON.toJSONString(obj, new SerializeFilter[]{scriptArrayFilter}, SerializerFeature.WriteMapNullValue); 
}

指定这个参数即可

SerializerFeature.WriteMapNullValue

属性说明

QuoteFieldNames———输出key时是否使用双引号,默认为true

WriteMapNullValue———是否输出值为null的字段,默认为false

WriteNullNumberAsZero———数值字段如果为null,输出为0,而非null

WriteNullListAsEmpty———List字段如果为null,输出为[],而非null

WriteNullStringAsEmpty———字符类型字段如果为null,输出为”“,而非null

WriteNullBooleanAsFalse———Boolean字段如果为null,输出为false,而非null

例子

String ret = JSON.toJSONStringWithDateFormat(returnValue, "yyyy-MM-dd HH:mm:ss",
                SerializerFeature.PrettyFormat,
                    // 保留map空的字段
                    SerializerFeature.WriteMapNullValue,
                    // 将String类型的null转成""
                    SerializerFeature.WriteNullStringAsEmpty,
                    // 将Number类型的null转成0
                    SerializerFeature.WriteNullNumberAsZero,
                    // 将List类型的null转成[]
                    SerializerFeature.WriteNullListAsEmpty,
                    // 将Boolean类型的null转成false
                    SerializerFeature.WriteNullBooleanAsFalse,
                    // 避免循环引用
                    SerializerFeature.DisableCircularReferenceDetect
                );

处理返回结果中字段为空或为null,不展示字段的问题(字段展示不全)

package com.aiqin.mgs.market.api.config; 
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.support.config.FastJsonConfig;
import com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
 
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;
 
/**
 * description: fastjson处理返回的参数为null、或者不返回
 * date: 2019/11/22 15:03
 * author: hantao
 * version: 1.0
 * springboot 处理返回结果中字段为空或为null,不展示字段的问题(字段展示不全)
 */
@Configuration
public class FastJsonConfiguration extends WebMvcConfigurationSupport {
 
    /**
     * 使用阿里 fastjson 作为JSON MessageConverter
     * @param converters
     */
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
        FastJsonConfig config = new FastJsonConfig();
        config.setSerializerFeatures(
                // 保留map空的字段
                SerializerFeature.WriteMapNullValue,
                // 将String类型的null转成""
                SerializerFeature.WriteNullStringAsEmpty,
                // 将Number类型的null转成0
                SerializerFeature.WriteNullNumberAsZero,
                // 将List类型的null转成[]
                SerializerFeature.WriteNullListAsEmpty,
                // 将Boolean类型的null转成false
                SerializerFeature.WriteNullBooleanAsFalse,
                // 避免循环引用
                SerializerFeature.DisableCircularReferenceDetect);
 
        converter.setFastJsonConfig(config);
        converter.setDefaultCharset(Charset.forName("UTF-8"));
        List<MediaType> mediaTypeList = new ArrayList<>();
        // 解决中文乱码问题,相当于在Controller上的@RequestMapping中加了个属性produces = "application/json"
        mediaTypeList.add(MediaType.APPLICATION_JSON);
        converter.setSupportedMediaTypes(mediaTypeList);
        converters.add(converter);
    }
 
    /**
     * 整合了swagger需要配置swagger拦截
     * @param registry
     */
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-ui.html","index.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
        registry.addResourceHandler("/static/**").addResourceLocations("classpath:/META-INF/resources/static/");
    } 
}

 /**
37          * 过滤器,发现传入的是null时,转化为""
38          */
39         ValueFilter filter = new ValueFilter() {
40             @Override
41             public Object process(Object obj, String s, Object v) {
42                 if (v == null)
43                     return "";
44                 return v;
45             }
46         };
47 
48         // 添加过滤器
49         System.out.println(JSONObject.toJSONString(jsonMap, filter));
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Fastjson是一种Java库,它提供了一种方便的方式来解析和生JSON数据。它可以将Java对象转换为JSON字符串,并将JSON字符串转换回Java对象。Fastjson提供了丰富的功能和选项,可以用于格式化JSON数据。 对于JSON格式化,Fastjson提供了几种选项,可以根据需求进行选择。其中一种选项是使用SerializerFeature.PrettyFormat,它可以使生JSON字符串具有良好的格式,易于阅读和理解。此外,Fastjson还提供了SerializerFeature.WriteMapNullValue用于保留Map中的空字段,SerializerFeature.WriteNullStringAsEmpty用于将String类型的null转换"",SerializerFeature.WriteNullNumberAsZero用于将Number类型的null转换0,SerializerFeature.WriteNullListAsEmpty用于将List类型的null转换[],SerializerFeature.WriteNullBooleanAsFalse用于将Boolean类型的null转换false。这些选项可以灵活地配置,以满足不同的需求。 下面是一个示例代码,演示了使用Fastjson进行JSON格式化的方法: ``` public static void main(String[] args) { String json = "{\"id\":1,\"name\":\"John\",\"age\":30}"; // 将JSON字符串转换为JSONObject JSONObject jsonObject = JSON.parseObject(json); // 使用PrettyFormat选项进行格式化 String formattedJson = JSON.toJSONString(jsonObject, SerializerFeature.PrettyFormat); System.out.println(formattedJson); } ``` 此代码将一个简单的JSON字符串转换为JSONObject对象,然后使用PrettyFormat选项对其进行格式化。最后,将格式化后的JSON字符串打印出来。 总结:Fastjson是一种用于解析和生JSON数据的Java库。它提供了多种选项,可以用于格式化JSON数据。在格式化,可以使用SerializerFeature.PrettyFormat选项使生JSON字符串易于阅读和理解。此外,还可以使用其他选项,如WriteMapNullValue、WriteNullStringAsEmpty等,来处理空字段和null值的转换。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值