FastJson 过滤/保留 NULL值问题,在远程调用过程传输中过滤了null值导致前端没有key

4 篇文章 1 订阅

简单的数据好像可以这样解决

Map<String, Object> map = JSONObject.parseObject(respJson, new TypeReference<Map<String, Object>>() {
});
这样可以转化为一个有null值的map,这样就不用考虑值为null的key被抹除的问题了(太坑了!)

FastJson介绍
fastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,支持将Java Bean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBean

最近项目中用到了FastJson,但是在操作的时候发现fastJson会对null值进行自动过滤,但是项目中需要保留null值,所以写下此文作为学习记录,有什么不对的地方,欢迎大家进行指正

下面是一些简单的demo

public static void main(String[] args) {
        Map<String,Object> data =  new HashMap<>();
        data.put("age",18);
        data.put("name","gonglei");
        data.put("sex",null);

        String jstr = JSON.toJSONString(data);
        System.err.println(jstr);
    }
输出结果为:
	{"name":"gonglei","age":18}

可以发现fastJson在进行转换的过程中是自动将null值进行了过滤,那如果不需要过滤呢?

public static void main(String[] args) {
        Map<String,Object> data =  new HashMap<>();
        data.put("age",18);
        data.put("name","gonglei");
        data.put("sex",null);

        String jstr = JSON.toJSONString(data, SerializerFeature.WriteMapNullValue);
        System.err.println(jstr);
    }
输出结果为:
	{"sex":null,"name":"gonglei","age":18}

对比两段代码,可以发现后段代码使用SerializerFeature.WriteMapNullValue将NULL值进行了保存

还有另外一种方法,但是本人还没来得及验证,由于项目中使用的是springboot,所以以下代码供大家参考

**在springboot启动类上加上如下代码**
	/**
     * 替换springboot默认的jackjson解析工具,使用fastjson进行解析json对象到前台
     *
     * @return HttpMessageConverters
     */
    @Bean
    public HttpMessageConverters fastJsonHttpMessageConverters() {
        // 1.需要定义一个convert转换消息的对象;
        FastJsonHttpMessageConverter fastJsonHttpMessageConverter = new FastJsonHttpMessageConverter();
        // 2:添加fastJson的配置信息;
        FastJsonConfig fastJsonConfig = new FastJsonConfig();
        fastJsonConfig.setSerializerFeatures(SerializerFeature.PrettyFormat,
                SerializerFeature.DisableCircularReferenceDetect, SerializerFeature.WriteMapNullValue,
                SerializerFeature.WriteNullStringAsEmpty, SerializerFeature.WriteNullListAsEmpty);
        // 3处理中文乱码问题
        List<MediaType> fastMediaTypes = new ArrayList<>();
        fastMediaTypes.add(MediaType.APPLICATION_JSON_UTF8);
        // 4.在convert中添加配置信息.
        fastJsonHttpMessageConverter.setSupportedMediaTypes(fastMediaTypes);
        fastJsonHttpMessageConverter.setFastJsonConfig(fastJsonConfig);
        HttpMessageConverter<?> converter = fastJsonHttpMessageConverter;
        return new HttpMessageConverters(converter);

    }

本项目用的是下面配置没有添加WriteMapNullValue

/**
	 * mvc @responseBody 使用fastJson
	 * 
	 * @return
	 */
	@Bean
	public HttpMessageConverters fastJsonHttpMessageConverters() {
		FastJsonHttpMessageConverter fastJsonHttpMessageConverter = new FastJsonHttpMessageConverter();
		List<MediaType> fastMediaTypes = new ArrayList<MediaType>();
		fastMediaTypes.add(MediaType.APPLICATION_JSON);
		FastJsonConfig fastJsonConfig = new FastJsonConfig();
		fastJsonConfig.setSerializeFilters(new PropertyFilter() {
			@Override
			public boolean apply(Object object, String name, Object value) {
				if(object.getClass().getSimpleName().equals("JSONObject")) {
					return true;
				}
				if(name.equals("returnCode") || name.equals("returnMsg") || 
						name.equals("pageIndex")  || name.equals("pageSize")  || name.equals("total") ) {
					if(value == null || value.equals("")) {
						return false;
					}
				}
				return true;
			}
		},new ValueFilter() {
			@Override
			public Object process(Object object, String name, Object value) {
				if(object.getClass().getSimpleName().equals("JSONObject")) {
					return value;
				}
				if(value != null) {
					return value;
				}
				Class<?> class1 = object.getClass();
				//类型是数字或字符串的时候
				Integer typei = ContextCache.responseType.get(class1.getSimpleName() + BaseConstant.POINT + name);
				if (typei == null) {
				    return value;
                }
				if (typei == 1 || typei == 6) {
					return "";
				}
				if (typei == 2 || typei == 7) {
					return null;
				}
				// 集合转换
				if (typei == 3 || Collection.class.isAssignableFrom(object.getClass())) {
					return Collections.emptyList();
				}
				
				// Map转换
				if (typei == 4) {
					return Collections.emptyMap();
				}
				// 数组转换
				if (typei == 5) {
					return Collections.emptyList();
				}
				// bean 转换
				try {
					if (typei == 0) {
						return new Object();
					}
				} catch (Exception e) {
				}
				return "";
			}
        });
		fastJsonConfig.setSerializerFeatures(SerializerFeature.WriteDateUseDateFormat,SerializerFeature.DisableCircularReferenceDetect);
		fastJsonHttpMessageConverter.setSupportedMediaTypes(fastMediaTypes);
		fastJsonConfig.setDateFormat("yyyy-MM-dd HH:mm:ss");
		fastJsonHttpMessageConverter.setFastJsonConfig(fastJsonConfig);
		fastJsonHttpMessageConverter.setDefaultCharset(Charset.forName("UTF-8"));
		HttpMessageConverter<?> converter = fastJsonHttpMessageConverter;
		return new HttpMessageConverters(converter);
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想在递归解析 JSON 数据时找到指定的,可以考虑使用递归函数来实现。以下是一个示例代码,可以实现在 JSON 数据查找指定的: ```java import com.alibaba.fastjson.*; public class JsonParser { public static void main(String[] args) { String jsonStr = "{\"name\":\"Jack\",\"age\":29,\"address\":{\"city\":\"New York\",\"zipcode\":\"12345\"}}"; String key = "zipcode"; String result = searchJson(jsonStr, key); System.out.println(result); } public static String searchJson(String jsonStr, String key) { Object obj = JSON.parse(jsonStr); if (obj instanceof JSONObject) { JSONObject jsonObj = (JSONObject) obj; for (String k : jsonObj.keySet()) { if (k.equals(key)) { return jsonObj.getString(k); } else { String result = searchJson(jsonObj.get(k).toString(), key); if (result != null) { return result; } } } } else if (obj instanceof JSONArray) { JSONArray jsonArray = (JSONArray) obj; for (Object arrayObj : jsonArray) { String result = searchJson(arrayObj.toString(), key); if (result != null) { return result; } } } return null; } } ``` 在上面的代码,我们定义了一个 `searchJson` 函数,它接受两个参数:一个是 JSON 字符串,另一个是要查找的键。该函数首先将 JSON 字符串解析为 `Object` 对象,然后判断该对象是 `JSONObject` 还是 `JSONArray`。如果是 `JSONObject`,则遍历该对象的每一个键对,如果键等于指定的键,则返回对应的;否则,递归调用 `searchJson` 函数继续查找。如果是 `JSONArray`,则遍历该数组的每一个元素,递归调用 `searchJson` 函数查找。 在上面的示例代码,我们查找的是 JSON 数据的 `zipcode` ,您可以根据实际需求修改查找的键。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值