前端和后端交互数据类型转换

页面是男/女 后端pojo类以及数据库中是Integer 0/1 怎么样很方便地转化?

复制代码
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Person implements Serializable {
    private static final long serialVersionUID = 4346092911489022673L;

    private Integer id;
    private String name;
    private Integer age;

    /**
     * 1 男,0 女
     */
    private Integer gender;

    @JsonDeserialize(using = GenderJsonDeserializer.class)
    public void setGender(Integer gender) {
        this.gender = gender;
    }

    @JsonSerialize(using = GenderJsonSerializer.class)
    public Integer getGender() {
        return gender;
    }
}

@Component
@Slf4j
public class GenderJsonDeserializer extends JsonDeserializer {

    @Override
    public Integer deserialize(JsonParser p, DeserializationContext ctxt)
            throws IOException, JsonProcessingException {
            
        if (ObjectUtils.isEmpty(p)) {
            return null;
        }

        int gender = 0;

        switch (p.getText()) {
            case "男":
                gender = 1;
                break;
            case "女":
                break;
            default:
                throw new RuntimeException("传入的性别为非法字符!");
        }

        log.info("【 GenderJsonDeserializer.deserialize() 】  p.getText() ==> " 
        				+ p.getText() + ",转换后的结果 ==> " + gender);

        return gender;
    }
}
java 复制代码
@Component
@Slf4j
public class GenderJsonSerializer extends JsonSerializer {
    @Override
    public void serialize(Object value, JsonGenerator gen, SerializerProvider serializers) 
    		throws IOException {
    		
        log.info("【 GenderJsonSerializer.serialize() 】  value ==> " + value);
        if (value.equals(1)) {
            gen.writeString("男");
        } else if (value.equals(0)) {
            gen.writeString("女");
        }
    }
}

----枚举转化--

在web开发中有时会使用枚举作为参数,而前端在调接口时就会出现传错或者传空导致后端拿不到枚举类型。在这里就使用反序列化@JsonDeserialize

这里是对枚举进行反序列化,所以首先编写一个类

public class EnumDeserializer extends JsonDeserializer<Enum<?>> {

@Override

public Enum<?> deserialize(JsonParser jp, DeserializationContext cxt) throws IOException {

String value = jp.getValueAsString();

if (StringUtils.isBlank(value))

return null;

Class findPropertyType = BeanUtils.findPropertyType(jp.currentName(), jp.getCurrentValue().getClass());

try {

return Enum.valueOf(findPropertyType, value);

} catch (IllegalArgumentException e) {

return null;

}

}

}

该类会判断前端传入的数据的某个字段是否能够解析为枚举,如果不能则返回null。

最后在传入的请求类的枚举字段上加入@JsonDeserialize注解

@JsonDeserialize(using = EnumDeserializer.class)

private EventEnum event;

而之后又遇到了数组枚举,那么在反序列化的时候的问题就主要是要拿到数组的泛型类,而通过反射可以做到这一点。

public class ListEnumDeserializer extends JsonDeserializer<List<Enum<?>>> {

@Override

public List<Enum<?>> deserialize(JsonParser jp, DeserializationContext cxt) throws IOException {

ArrayNode treeNode = jp.readValueAsTree();

Field field;

try {

field = jp.getCurrentValue().getClass().getDeclaredField(jp.currentName());

} catch (NoSuchFieldException e) {

return null;

}

field.setAccessible(true);

if (!field.getType().equals(List.class)) {

return null;

}

ParameterizedType genericType = (ParameterizedType) field.getGenericType();

Class actualTypeArgument = (Class) genericType.getActualTypeArguments()[0];

List<Enum<?>> result = new ArrayList<>();

Iterator<JsonNode> elements = treeNode.elements();

while (elements.hasNext()) {

String appCase = elements.next().asText();

try {

Enum anEnum = Enum.valueOf(actualTypeArgument, appCase);

result.add(anEnum);

} catch (IllegalArgumentException e) {

continue;

}

}

if (result.isEmpty()) {

return null;

} else {

return result;

}

}

}

同样在最后字段上加入注解

@JsonDeserialize(using = ListEnumDeserializer.class)

private List<AppCaseEnum> appCase;

相关推荐
人道领域7 分钟前
SSM框架从入门到入土(AOP面向切面编程)
java·开发语言
铅笔侠_小龙虾8 分钟前
Flutter 实战: 计算器
开发语言·javascript·flutter
2的n次方_26 分钟前
Runtime 执行提交机制:NPU 硬件队列的管理与任务原子化下发
c语言·开发语言
大模型玩家七七28 分钟前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
2501_9447114344 分钟前
JS 对象遍历全解析
开发语言·前端·javascript
CodeToGym1 小时前
【Java 办公自动化】Apache POI 入门:手把手教你实现 Excel 导入与导出
java·apache·excel
凡人叶枫1 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
Tony Bai1 小时前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
JMchen1231 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
小糯米6012 小时前
C++顺序表和vector
开发语言·c++·算法