SpringBoot返回对象NULL转空字符串

一、使用场景

        前端要求返回的对象,如果String类型没有值要返回空字符串,没有值要数组返回空数组,然而后台直接返回的话,是NULL值,需要手动处理,为了简便配置WebMvcConfigurationSupport即可

二、实例

1、配置MyFastJsonConfig继承WebMvcConfigurationSupport

2、重写configureMessageConverters,实现返回对应的空字符串和空对象

3、重写addResourceHandlers,添加静态资源,以免访问不到

三、代码

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 org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter;

import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;

/**
 * 返回值处理
 * NULL转空字符串
 * @author lyc
 */
@Configuration
public class MyFastJsonConfig extends WebMvcConfigurationSupport {

    /**
     * 使用阿里 fastjson 作为JSON MessageConverter
     * 需要fastjson依赖
     * <dependency>
     *     <groupId>com.alibaba</groupId>
     *     <artifactId>fastjson</artifactId>
     *     <version>1.2.76</version>
     * </dependency>
     * @param converters
     */

    /**
     * 源码解释:
     *  重写此方法以添加自定义 {@link HttpMessageConverter HttpMessageConverters}
     *  以与 {@link RequestMappingHandlerAdapter}
     *  和 {@link ExceptionHandlerExceptionResolver} 一起使用。
     *  <p>将转换器添加到列表会关闭默认情况下会注册的默认转换器。另请参阅 {@link addDefaultHttpMessageConverters}
     *  添加默认消息转换器。
     *  @param converters 将消息转换器添加到的列表(最初是一个空列表)
     *
     *
     * Override this method to add custom {@link HttpMessageConverter HttpMessageConverters}
     * to use with the {@link RequestMappingHandlerAdapter} and the
     * {@link ExceptionHandlerExceptionResolver}.
     * <p>Adding converters to the list turns off the default converters that would
     * otherwise be registered by default. Also see {@link #addDefaultHttpMessageConverters}
     * for adding default message converters.
     * @param converters a list to add message converters to (initially an empty list)
     */
    @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);
    }

    /**
     * 源码解释:
     *  覆盖此方法以添加资源处理程序以提供静态资源
     * 	Override this method to add resource handlers for serving static resources.
     * 	@see ResourceHandlerRegistry
     *
     * 解决的问题:
     *  静态资源不可以访问,例如swagger页面
     *
     *  @param registry
     */
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler(new String[]{"/**"})
                .addResourceLocations(new String[]{"classpath:/static/"});
        registry.addResourceHandler(new String[]{"doc.html"})
                .addResourceLocations(new String[]{"classpath:/META-INF/resources/"});
        registry.addResourceHandler(new String[]{"/webjars/**"})
                .addResourceLocations(new String[]{"classpath:/META-INF/resources/webjars/"});
        super.addResourceHandlers(registry);
    }
}

四、测试

1、创建实体类

/**
 * @author lyc
 */
@Data
public class MyUser {
    private String name;
    private List<String> subjects;
}

2、创建controller

/**
 * @author lyc
 */
@Controller
public class MyController {

    @RequestMapping("/getUser")
    public MyUser getUser(){
        return new MyUser();
    }

}

3、访问看返回值

{
  "code": "000000",
  "data": {
    "name": "",
    "subjects": []
  },
  "msg": "执行成功"
}

4、结果对比

     处理后:

    处理前:

 

 

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将null转换成空字符串,可以使用以下方法: 引用\[1\]中的代码是一个将单个对象中的String类型的null字段转换为空字符串的方法。该方法接受一个待转化对象作为参数,并遍历对象的所有字段。如果字段的类型是String并且值为null,就将其设置为空字符串。 引用\[2\]中的代码是一个将集合中的所有对象中的String类型的null字段转换为空字符串的方法。该方法接受一个待转化的集合作为参数,并遍历集合中的每个对象。对于每个对象,它会遍历对象的所有字段,如果字段的类型是String并且值为null,就将其设置为空字符串。 引用\[3\]中提到了在控制层将对象序列化返回给前端时,有些字段为null,可以对jackson稍加修改,将值为null的转换成空字符串""。具体的实现方法可以参考引用\[3\]中的代码。 所以,根据以上方法,你可以将null转换成空字符串。 #### 引用[.reference_title] - *1* *2* [使用工具类把对象中的null值转换为空字符串(集合也可以使用)](https://blog.csdn.net/qq_44580165/article/details/126140038)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [SpringBoot使用Jackson序列化时将null转成空字符串](https://blog.csdn.net/backbug/article/details/105316517)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值