【Java 问题 & 解决方法 · SpringBoot & Jackson】Enum类型 转JSON无法获取内部属性

该博客介绍了如何在Java中使用Enum类型并结合Lombok处理前后端信息传递。通过在Enum中添加@JsonValue注解的方法toMap(),使得Enum对象在转化为JSON时能直接获取到内部属性code和msg,简化了前端的数据处理。测试代码展示了转换后的JSON对象可以直接包含所需信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、问题描述

情景:现限制必须使用 Enum类型,协助在前后端间传递部分规范化信息,
且保证 enum 对象 内部属性可直接获取(可以使用lombok协助处理):

@Getter
@AllArgsConstructor
enum RespCode{
	SEND_SUCCESS(200,"发送成功!"),
	SOMETHING_ERROR(400,"XXX出错!")
	;
	
	int code;
	String msg;
}

若如此简单操作,当需要将 enum 类型 转换为JSON对象时,我们只能获取到状态名称(如"SEND_SUCCESS"),无法直接找到对应的属性。

POM引入Jackson依赖(测试使用):

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.12.5</version>
</dependency>

测试代码如下:

ObjectMapper mapper = new ObjectMapper();
String json = mapper.writeValueAsString(RespCode.SEND_SUCCESS);
System.out.println("JSON对象:" + json);

结果

二、解决方法

为了能更加方便地获取属性,我们 构建方法toMap(),并加上@JsonValue注解,通过这种方法,改变JSON转化调用的方法:

@Getter
@AllArgsConstructor
enum RespCode{
	SEND_SUCCESS(200,"发送成功!"),
	SOMETHING_ERROR(400,"XXX出错!")
	;
	
	int code;
	String msg;

	@JsonValue
	public Map<String,Object> toMap(){
		Map<String,Object> map = new HashMap<>();
		map.put("code",getCode());
		map.put("msg ",getMsg());
		return map;
	}
}

再次测试,这次可直接获取到我们需要的信息:
结果
这样可以保证前端对信息的直接使用,无需做任何处理,更加便捷。

Java获取MySQL的ENUM类型值,可以使用JDBC连接到数据库并执行查询语句。查询语句中使用SELECT语句来获取ENUM类型字段的值,然后使用ResultSet对象的getString()方法获取该字段的字符串值。 以下是一个示例代码: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class EnumTest { public static void main(String[] args) throws Exception { // JDBC连接MySQL数据库 String url = &quot;jdbc:mysql://localhost:3306/mydatabase&quot;; String user = &quot;root&quot;; String password = &quot;password&quot;; Connection conn = DriverManager.getConnection(url, user, password); // 查询ENUM类型字段的值 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(&quot;SELECT my_enum_field FROM my_table&quot;); // 遍历结果集,获取ENUM类型值 while (rs.next()) { String enumValue = rs.getString(&quot;my_enum_field&quot;); System.out.println(enumValue); } // 关闭连接 rs.close(); stmt.close(); conn.close(); } } ``` 在上面的示例中,假设有一个名为&quot;my_table&quot;的表,其中包含一个名为&quot;my_enum_field&quot;的ENUM类型字段。通过JDBC连接到MySQL数据库,并执行SELECT语句获取&quot;my_enum_field&quot;字段的值。遍历结果集,使用getString()方法获取ENUM类型值,并打印到控制台。 需要注意的是,ENUM类型值在Java中是以字符串形式表示的。如果需要将字符串值换为枚举类型,可以使用Java枚举类来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值