前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java使用jackson标准化输出文件格式

java使用jackson标准化输出文件格式

作者头像
查拉图斯特拉说
发布2023-12-21 08:51:42
1870
发布2023-12-21 08:51:42
举报
文章被收录于专栏:后端架构

前言

当设计接口的时候,有时候总是需要去对不同的一些指标数据去进行一个格式化输出。通常可能会写一个实现方法。可能还不太一定能复用。今天这一节主要讲的是一个利用注解的方式。调用它的一些序列化方法对参数的结果。进行一个标准化格式输出,而且代码你还能够复用。非常的简单,方便。

操作步骤

首先,我们需要去实现。一个jason的序列化接口。你需要声明泛型的类型,也就是你需要注入的类型。然后你再实现他自己的一些重写他的方法。对他的方法进行一个逻辑处理到这里,基本上逻辑处理这一步已经完成了,剩下的你只需要加一些异常判断之类的就可以了。

具体逻辑处理代码

代码语言:javascript
复制
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.SerializerProvider;

import java.io.IOException;
import java.math.BigDecimal;
import java.math.RoundingMode;

/**
 * 文件大小转化成标准单位输出
 *
 * @author Steven
 * @Date 2022/8/19 10:46
 */
public class FileSizeToStandardStrConverter extends JsonSerializer<Long> {

    private final int GB = 1024 * 1024 * 1024;
    private final int MB = 1024 * 1024;
    private final int KB = 1024;

    private String fileSizeToStandardStr(Long fileSize) {
        if (fileSize >= GB) {
            return getDivide(fileSize, GB).toPlainString() + "G";
        } else if (fileSize >= MB) {
            return getDivide(fileSize, MB).toPlainString() + "M";
        } else if (fileSize >= KB) {
            return getDivide(fileSize, KB).toPlainString() + "K";
        } else {
            return fileSize.toString() + "B";
        }
    }

    private BigDecimal getDivide(Long fileSize, Integer standardSize) {
        return BigDecimal.valueOf(fileSize).divide(BigDecimal.valueOf(standardSize), 1, RoundingMode.HALF_DOWN);
    }

    @Override
    public void serialize(Long value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
        if (value != null) {
            gen.writeString(fileSizeToStandardStr(value));
        }
    }
}

使用注解

然后接着你还是需要到某一个返回的实体类里面的属性上面标上jason的序列化注解,然后指定使用某一个类的。累这样在你返回结果的时候,它自动会调用相应的处理类进行一个格式化输出,非常的简单,方便,而且自己非常的简洁,方便了代码的可读性,你可以在任何实体类上面都可以去使用它。他反式电话的时候自动会调用实现。当然他也可以自定义到某个方法上面。

代码语言:javascript
复制
    @ApiModelProperty(value = "文件大小(为空就是不存在,否则就会显示大小加单位)", example = "21M")
    @JsonSerialize(using = FileSizeToStandardStrConverter.class)
    private Long fileSize;

总结

本文介绍了一种通过注解技术统一不同参数结果输出方式、提高代码复用性的设计理念。具体步骤包括创建JSON序列化接口,标记需注入的泛型类型,并实现及重写对应逻辑处理函数。通过为实体类属性添加JSON序列化注解并指定类,系统会自动找到相应处理类进行格式化输出,简化复杂编码,提高代码可读性。更重要的是,这种方法具有灵活性和针对性,用户可以在任何实体类或特定方法中定制相关操作。

最后

点赞关注评论一键三连,每周分享技术干货、开源项目、实战经验、国外优质文章翻译等,您的关注将是我的更新动力!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-12-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 操作步骤
  • 具体逻辑处理代码
  • 使用注解
  • 总结
  • 最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档