在我们平时开发中,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转为voTestJsonVo 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返回给前端。
好,这篇就这样儿~~~