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

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

相关推荐
Derek_Smart几秒前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP1 小时前
MyBatis-mybatis入门与增删改查
java
孟陬4 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌4 小时前
一站式了解四种限流算法
java·后端·go
华仔啊5 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝6 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java
Nyarlathotep01136 小时前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen56 小时前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing7 小时前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员