当前位置: 首页 > article >正文

springboot中DTO、VO、Entity相互转换

在我们平时开发中,dto、vo、entity之间的相互转换是很频繁的操作,这篇就简单记录一下我在平时开发中转换的方法。

在这之前先简单描述一下dto、vo、entity

DTO:一般我们在开发中会定义数据传输对象(Data Transfer Object, DTO)来接收前端传递的参数是最常见的。

VO:平时开发中,一般会定义VO(view object)来封装返回给前端的数据

Entity:在我们开发中,Entity适用于表示持久化对象的核心组件之一。它通常与数据库中的表直接对应,用于映射数据库记录到应用程序的对象

我们在平时的增删改查中,简单来说就是

就像新增操作,一般会使用dto来接受前端传递的参数,然后将dto转为Entity,再set一些创建时间之类的字段,然后再将Entity实体对象数据插入到数据库中。

查询操作,先从数据库查询出数据即Entity,然后再将Entity转为VO视图数据,再返回给前端。

我这里平时开发中,会使用下面封装的工具类来进行dto、vo、entity之间的转换,代码如下:

首先pom.xml引入依赖:

<!-- JSON 解析器和生成器 -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.83</version>
</dependency>

封装JSONUtil类 

package com.wft.utils;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.TypeReference;
import com.alibaba.fastjson.parser.Feature;
import com.alibaba.fastjson.serializer.SerializerFeature;
import java.util.List;
import java.util.Map;

public class JsonUtil {
    public JsonUtil() {

    }

    public static List listToJsonField(List lists) {
        String jsonStr = JSONArray.toJSONString(lists, new SerializerFeature[]{SerializerFeature.WriteMapNullValue});
        List list = (List)JSONArray.parseObject(jsonStr, List.class);
        return list;
    }

    public static Map<String, Object> entityToMap(Object object) {
        String jsonStr = JSONObject.toJSONString(object);
        Map<String, Object> map = (Map)JSONObject.parseObject(jsonStr, new TypeReference<Map<String, Object>>() {
        }, new Feature[0]);
        return map;
    }

    public static Map<String, String> entityToMaps(Object object) {
        String jsonStr = JSONObject.toJSONString(object);
        Map<String, String> map = (Map)JSONObject.parseObject(jsonStr, new TypeReference<Map<String, String>>() {
        }, new Feature[0]);
        return map;
    }

    public static Map<String, Object> stringToMap(String object) {
        Map<String, Object> map = (Map)JSONObject.parseObject(object, new TypeReference<Map<String, Object>>() {
        }, new Feature[0]);
        return map;
    }

    public static <T> T getJsonToBean(String jsonData, Class<T> clazz) {
        return JSON.parseObject(jsonData, clazz);
    }

    public static JSONArray getJsonToJsonArray(String json) {
        return JSONArray.parseArray(json);
    }

    public static <T> JSONArray getListToJsonArray(List<T> list) {
        return JSONArray.parseArray(getObjectToString(list));
    }

    public static String getObjectToString(Object object) {
        return JSON.toJSONString(object, new SerializerFeature[]{SerializerFeature.WriteMapNullValue});
    }

    public static String getObjectToStringDateFormat(Object object, String dateFormat) {
        return JSON.toJSONStringWithDateFormat(object, dateFormat, new SerializerFeature[]{SerializerFeature.WriteMapNullValue});
    }

    public static <T> List<T> getJsonToList(String jsonData, Class<T> clazz) {
        return JSON.parseArray(jsonData, clazz);
    }

    public static List<Map<String, Object>> getJsonToListMap(String jsonData) {
        return (List)JSON.parseObject(jsonData, new TypeReference<List<Map<String, Object>>>() {
        }, new Feature[0]);
    }

    public static List<Map<String, Object>> getJsonToList(JSONArray jsonArray) {
        return (List)JSON.parseObject(JSON.toJSONString(jsonArray), new TypeReference<List<Map<String, Object>>>() {
        }, new Feature[0]);
    }

    public static <T> T getJsonToBean(Object dto, Class<T> clazz) {
        return JSON.parseObject(getObjectToString(dto), clazz);
    }

    public static <T> List<T> getJsonToList(Object dto, Class<T> clazz) {
        return JSON.parseArray(getObjectToString(dto), clazz);
    }
}

平时使用中我一般使用最多的就是JsonUtil.getJsonToBean方法,就是进行dto、vo、entity对象之间的相互转换,简单聚个例子如下:

示例:

前端传递DTO(name、age、birthTime)过来,然后我们转为VO(ame、age、birthTime、creatorTime)并返回。

DTO类:

package com.wft.model.testJson;

import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Data;

@Data
public class TestJsonForm {

    /** 姓名 **/
    @JsonProperty("name")
    private String name;

    /** 年龄 **/
    @JsonProperty("age")
    private Integer age;

    /** 出生日期 **/
    @JsonProperty("birthTime")
    private String birthTime;

}

 VO:

package com.wft.model.testJson;

import com.alibaba.fastjson.annotation.JSONField;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;

import java.util.Date;

@Data
public class TestJsonVo {

    @JSONField(name = "name")
    private String name;

    @JSONField(name = "age")
    private Integer age;

    @JSONField(name = "birthTime")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
    private Date birthTime;

    @JSONField(name = "birthTime")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
    private Date creatorTime;
}

Controller:

package com.wft.controller;

import com.wft.model.ActionResult;
import com.wft.model.testJson.TestJsonForm;
import com.wft.model.testJson.TestJsonVo;
import com.wft.utils.JsonUtil;
import org.springframework.web.bind.annotation.*;

import java.util.Date;

@RestController
@RequestMapping("/json")
public class TestJsonController {

    @PostMapping("/save")
    public ActionResult uploadTest(@RequestBody TestJsonForm testJsonForm) {
        // 将dto转为vo
        TestJsonVo vo = JsonUtil.getJsonToBean(testJsonForm, TestJsonVo.class);
        vo.setCreatorTime(new Date());
        return ActionResult.success(vo);
    }

}

@JsonProperty

大家能看到DTO中,我使用了 @JsonProperty 注解,这个很简单,其实就是标识前端传递的参数字段是什么,就是允许我们后端接受的参数字段和前端传递的字段可以不一致,如果不一致我们后端就可以使用@JsonProperty进行映射。

上面我们定义的name字段,如果前端传递的字段为cusname,我们就可以在name字段上使用这样的注解@JsonProperty("cusname")这样设置。

@JSONField

同样的我在VO中使用@JSONField注解,上面的例子是把DTO转为VO,VO中的@JSONField对应的就是DTO中的字段

其实我们平时开发中,只要字段都对应好,完全不需要使用这两个注解。 

上面VO中还使用了@JsonFormat 注解,这个是格式化时间的,将Date类型转为String类型yyyy-MM-dd HH:mm:ss返回给前端。 

好,这篇就这样儿~~~


http://www.kler.cn/a/517963.html

相关文章:

  • 狗狗能吃萝卜吗?
  • Transfoemr的解码器(Decoder)与分词技术
  • macOS使用LLVM官方发布的tar.xz来安装Clang编译器
  • Hook 函数
  • 与机器学习相关的概率论重要概念的介绍和说明
  • ThreeJS示例教程200+【目录】
  • 低代码系统-产品架构案例介绍、得帆云(九)
  • 如何用VSCODE配置C++多文件编译
  • three.js+WebGL踩坑经验合集(2):3D场景被相机裁切后,被裁切的部分依然可以被鼠标碰撞检测得到(射线检测)
  • 豆包MarsCode:小C的类二进制拼图
  • ansible自动化运维实战--yaml的使用和配置(7)
  • http请求获取客户端ip
  • Flink(十一): DataStream API (八) Checkpointing
  • Arduino大师练成手册 -- 读取DS18B20
  • MacOS安装Docker battery-historian
  • 编译安装PaddleClas@openKylin(失败,安装好后报错缺scikit-learn)
  • 知识体系_统计学_03_描述性统计_概括性度量
  • 2025数学建模美赛|B题成品论文
  • GraphRAG 简介
  • 「全网最细 + 实战源码案例」设计模式——原型模式
  • 使用 Docker Compose 一键启动 Redis、MySQL 和 RabbitMQ
  • Linux 常用命令——软件篇(保姆级说明)
  • 13.快速构建领域知识库的完整指南:结合 ChatGPT 与 Python 提升效率
  • kafka-部署安装
  • 自定义注解
  • tkinter绘制组件(44)——浮出ui控件