fastjson:获取类(Class)的所有可序列化字段(field)

本文介绍使用FastJSON库中的TypeUtils.computeGetters方法来获取指定类的所有可序列化字段名称及类型。通过示例代码展示了如何针对一个具体类(如Group类)获取其所有可序列化的字段信息。

用fastjson对一个类进行序列化时,在没有类的实例只有类的Class的情况下,如果想知道这个Class有所有可以被序列化的字段名,可以用com.alibaba.fastjson.util.TypeUtils.computeGetters(Class<?> clazz, Map<String, String> aliasMap)方法来实现,实现代码很简单:

package net.gdface.facelog.message;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.junit.Test;

import com.alibaba.fastjson.util.FieldInfo;

public class TestFastjson {
	@Test
	public void testComputeGetters(){
		// 返回 Group 类所有可序列化字段信息
		List<FieldInfo> fieldInfo = com.alibaba.fastjson.util.TypeUtils.computeGetters(Group.class, null);
		// 输出字段名和类型
		for(FieldInfo field:fieldInfo){
			System.out.printf("name %s %s\n",field.name,field.fieldType.toString());
		}
	}
	public interface Person<T>{
		
	}
	public static class User implements Person<String>{

	    private Long   id;
	    private String name;


	    public Long getId() {
	        return id;
	    }

	    public void setId(Long id) {
	        this.id = id;
	    }

	    public String getName() {
	        return name;
	    }

	    public void setName(String name) {
	        this.name = name;
	    }

	}
	public static  class Group {

	    private Long       id;
	    private String     name;
	    private List<User> users = new ArrayList<User>();
	    public Date date=new Date();
	    public java.sql.Date sqldate=new java.sql.Date(date.getTime());
	    public byte[] array=new byte[]{22,33,3,2,3,1,5,-1};
	    public String nullStr=null;
	    private String privString="private string";
	    public Long getId() {
	        return id;
	    }

	    public void setId(Long id) {
	        this.id = id;
	    }

	    public String getName() {
	        return name;
	    }

	    public void setName(String name) {
	        this.name = name;
	    }

	    public List<User> getUsers() {
	        return users;
	    }

	    public void setUsers(List<User> users) {
	        this.users = users;
	    }

	        public void addUser(User user) {
	            users.add(user);
	        }
	}

}

测试代码运行输出

name array class [B
name date class java.util.Date
name id class java.lang.Long
name name class java.lang.String
name nullStr class java.lang.String
name sqldate class java.sql.Date
name users java.util.List<net.gdface.facelog.message.TestFastjson2$User>

### Fast 序列化指定字段的方法及实现方式 在 JSON序列化过程中,有时我们只需要对特定的字段进行序列化而忽略其他字段。对于 `fastjson` 这样的工具来说,可以通过多种方式进行配置来满足这一需求。 #### 方法一:通过注解控制字段序列化 可以使用 `@JSONField(serialize=false)` 注解标记不需要被序列化字段。这种方式允许开发者灵活地决定哪些字段应该参与序列化过程[^4]。例如: ```java public class User { @JSONField(name = "username", ordinal = 1) private String name; @JSONField(serialize = false) private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } } ``` 上述代码中,`age` 字段不会被序列化到最终的结果中,因为其上标注了 `@JSONField(serialize = false)` 属性。 #### 方法二:通过自定义 Serializer 实现更复杂的逻辑 如果需要更加精细地控制序列化行为,则可以创建一个自定义的 `SerializerFeature` 或者继承默认的序列器并重写其中的部分功能。以下是基于 Java 的示例代码片段: ```java import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.serializer.ValueFilter; public class CustomValueFilter implements ValueFilter { @Override public Object process(Object object, String name, Object value) { if ("password".equals(name)) { return null; // 不希望密码出现在结果里 } else { return value; } } } // 使用时调用如下: User user = new User(); String jsonString = JSON.toJSONString(user, new CustomValueFilter()); System.out.println(jsonString); ``` 此方法利用了一个过滤器机制,在实际应用中可以根据业务场景调整具体规则。 #### 方法三:借助 ResponseModel 定义返回结构 当涉及到 Web 开发框架(如 FastAPI),则推荐直接采用响应模型的方式定义接口输出的内容形式。这样不仅能够清晰表达数据契约关系,还便于维护团队协作开发效率[^3]。比如下面这个例子展示了如何仅暴露部分实体属性给客户端: ```python from pydantic import BaseModel class PublicUserInfo(BaseModel): username: str @app.get("/users/{id}", response_model=PublicUserInfo) async def read_user(id: int): full_info = fetch_full_user_from_db(id=id) return {"username": full_info['name']} ``` 这里的关键在于设置了 `response_model=PublicUserInfo` 参数,从而限定了 API 返回的数据范围只包含用户名信息。 --- ### 总结 综上所述,无论是使用像 fastjson 这样强大的第三方库还是现代编程语言自带的功能模块,都可以找到合适的技术手段去解决“按需序列化”的问题。选择何种方案取决于项目背景以及个人偏好等因素综合考量之后再做定夺。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

10km

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值