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

页面是男/女 后端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;

相关推荐
工业甲酰苯胺19 小时前
实现 json path 来评估函数式解析器的损耗
java·前端·json
老前端的功夫19 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
@forever@19 小时前
【JAVA】LinkedList与链表
java·python·链表
LilySesy19 小时前
ABAP+WHERE字段长度不一致报错解决
java·前端·javascript·bug·sap·abap·alv
六件套是我19 小时前
redission实现延时队列
android·java·servlet
王元_SmallA20 小时前
Redis Desktop Manager(Redis可视化工具)安装
java·后端
ᐇ95920 小时前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
好好研究20 小时前
Spring框架 - 开发方式
java·后端·spring
武子康20 小时前
Java-166 Neo4j 安装与最小闭环 | 10 分钟跑通 + 远程访问 Docker neo4j.conf
java·数据库·sql·docker·系统架构·nosql·neo4j
QT 小鲜肉20 小时前
【个人成长笔记】在 Linux 系统下撰写老化测试脚本以实现自动压测效果(亲测有效)
linux·开发语言·笔记·单片机·压力测试