java只返回实体类中的部分字段问题如何解决

java只返回实体类中的部分字段问题如何解决

本文讲解"java只返回实体类中的部分字段问题怎么解决",希望能够解决相关问题。

如何只返回实体类中的部分字段

在实体类上添加注解

@jsoninclude(jsoninclude.include.non_empty)

表示实体类中为null,空字符串,空集合数组等内容不会被序列化,即不会返回字段和值。

以下为对注解所有取值的简介

always // 默认策略,任何情况都执行序列化
non_null // 非空
non_absent // null的不会序列化,但如果类型是atomicreference,依然会被序列化
non_empty // null、集合数组等没有内容、空字符串等,都不会被序列化
non_default // 如果字段是默认值,就不会被序列化
custom // 此时要指定valuefilter属性,该属性对应一个类,用来自定义判断被jsoninclude修饰的字段是否序列化
use_defaults // 当jsoninclude在类和属性上都有时,优先使用属性上的注解,此时如果在序列化的get方法上使用了jsoninclude,并设置为use_defaults,就会使用类注解的设置

java动态添加实体类字段并返回给前端

工具类

package com.bless.wms.utils;
import lombok.extern.slf4j.slf4j;
import org.apache.commons.beanutils.propertyutilsbean;
import org.springframework.cglib.beans.beangenerator;
import org.springframework.cglib.beans.beanmap;
import java.beans.propertydescriptor;
import java.lang.reflect.invocationtargetexception;
import java.util.hashmap;
import java.util.map;
/**
 * 动态添加实体类字段
 */
@slf4j
public final class propertyappender {
    private static final class dynamicbean {
        private object target;
        private beanmap beanmap;
        private dynamicbean(class superclass, map propertymap) {
            this.target = generatebean(superclass, propertymap);
            this.beanmap = beanmap.create(this.target);
        }
        private void setvalue(string property, object value) {
            beanmap.put(property, value);
        }
        private object getvalue(string property) {
            return beanmap.get(property);
        }
        private object gettarget() {
            return this.target;
        }
        /**
         * 根据属性生成对象
         */
        private object generatebean(class superclass, map propertymap) {
            beangenerator generator = new beangenerator();
            if (null != superclass) {
                generator.setsuperclass(superclass);
            }
            beangenerator.addproperties(generator, propertymap);
            return generator.create();
        }
    }
    public static object generate(object dest, map newvaluemap) throws invocationtargetexception, illegalaccessexception {
        propertyutilsbean propertyutilsbean = new propertyutilsbean();
        //1.获取原对象的字段数组
        propertydescriptor[] descriptorarr = propertyutilsbean.getpropertydescriptors(dest);
        //2.遍历原对象的字段数组,并将其封装到map
        map oldkeymap = new hashmap<>();
        for (propertydescriptor it : descriptorarr) {
            if (!"class".equalsignorecase(it.getname())) {
                oldkeymap.put(it.getname(), it.getpropertytype());
                newvaluemap.put(it.getname(), it.getreadmethod().invoke(dest));
            }
        }
        //3.将扩展字段map合并到原字段map中
        newvaluemap.foreach((k, v) -> oldkeymap.put(k, v.getclass()));
        //4.根据新的字段组合生成子类对象
        dynamicbean dynamicbean = new dynamicbean(dest.getclass(), oldkeymap);
        //5.放回合并后的属性集合
        newvaluemap.foreach((k, v) -> {
            try {
                dynamicbean.setvalue(k, v);
            } catch (exception e) {
                log.error("动态添加字段【值】出错", e);
            }
        });
        return dynamicbean.gettarget();
    }
}

调用

前端接口调用测试

备注:前端表格直接for循环动态渲染就ok了

相关文章