DTO到entity自动赋值

简介: DTO到entity自动赋值

6ca69a34ad3c307086fa98724b24e19d.jpg

DTO到entity自动赋值


实体与Dto自动赋值

在开发的过程中,实体之间相互赋值是很正常的事,但是我们一般的方法都通过set和get方法来进行的,如果要赋值的字段少那还行,但是需要赋值的字段超过10个,那就是个灾难,你会看到整屏代码中全是set和get方法。两个实体属性字段几乎完全相同 两个字体有部分字段相同 源实体只有部分字段赋值,目标实体有完整的值


第一种情况

对于第1点来说,我们用到最多的就是entity和dto之间的转换了,这个我们可以使用Spring的工具类BeanUtils来解决,这里要注意的一点是,==第一个参数是源,第二个参数是目标==。

import org.springframework.beans.BeanUtils;
BeanUtils.copyProperties(origin, target);


第二种情况

但是对于第2点来说,就没有那么简单了,再使用BeanUtils已经不能满足我们的需要了。我们可以使用jackson的ObjectMapper

import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.ObjectReader;
import com.jd.fastjson.JSON;
ObjectMapper objectMapper = new ObjectMapper();
//配置该objectMapper在反序列化时,忽略目标对象没有的属性。凡是使用该objectMapper反序列化时,都会拥有该特性。
objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
//读入需要更新的目标实体
ObjectReader objectReader = objectMapper.readerForUpdating(target);
//将源实体的值赋值到目标实体上
objectReader.readValue(JSON.toJSONString(source));

我们总结一下objectMapper的过滤参数:

/*
 通过该方法对mapper对象进行设置,所有序列化的对象都将按改规则进行系列化
 Include.Include.ALWAYS 默认
 Include.NON_DEFAULT 属性为默认值不序列化
 Include.NON_EMPTY 属性为 空(“”) 或者为 NULL 都不序列化
 Include.NON_NULL 属性为NULL 不序列化
 */
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_DEFAULT);
String outJson = objectMapper.writeValueAsString(productDetail);
//上面代码里,outJson的值将会过滤掉只有默认值的属性


第三种情况

本情况主要对于从dto到entity转换过程中出现 ,比如一个put操作,前端可能只修改某几个属性,而在后端处理时也只希望处理这几个被赋值的属性,这时我们使用下面的方法:

@RequestMapping(value = "/{id}", method = RequestMethod.PUT)
    public HttpEntity update(@PathVariable int id, @RequestBody ProductDetail productDetail)
            throws IOException {
        ProductDetail existing = repository.findById(id).get();
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_DEFAULT);
        String outJson = objectMapper.writeValueAsString(productDetail);
        ObjectReader objectReader = objectMapper.readerForUpdating(existing);
        objectReader.readValue(outJson);
        repository.save(existing);
        return new ResponseEntity<>(existing, HttpStatus.ACCEPTED);
    }

通过objectMapper的使用,可以让我们少写很多重复的代码。

目录
相关文章
|
6月前
|
设计模式 前端开发 Java
DTO和VO的区别及使用场景详解
DTO和VO的区别及使用场景详解
4404 0
|
JSON Java Apache
Bean自动映射工具对比及VO、DTO、PO、DO对象之间的转换
在实际的开发过程中,常常遇到各个层之间对象转换,比如 VO、DTO、PO、DO 等,而如果都是手动set、get,一旦属性较多时,操作起来不仅麻烦,而且浪费时间,因此经常会使用一些工具类,进行对象之间的转换,下面将对象与对象之间转换的方式进行对比,一级对象间的使用进行总结。
Bean自动映射工具对比及VO、DTO、PO、DO对象之间的转换
|
2月前
|
设计模式 开发框架 Java
分清 PO、VO、DAO、BO、DTO、POJO 含义
分清 PO、VO、DAO、BO、DTO、POJO 含义
|
6月前
|
设计模式 开发框架 前端开发
VO、PO、DTO的区别
VO、PO、DTO的区别
517 3
|
6月前
|
前端开发 Java 数据库连接
PO、VO、DAO、BO、DTO、POJO之间的差异与联系
PO、VO、DAO、BO、DTO、POJO之间的差异与联系
259 0
|
Java 数据库
详述 PO VO BO DTO DAO 和 POJO 的概念及区别
详述 PO VO BO DTO DAO 和 POJO 的概念及区别
214 0
|
设计模式 前端开发 Java
Java开发中PO、VO、DAO、BO、DTO、POJO 含义
可以看成是与数据库中的表相映射的java对象。使用 Mybatis 来生成 PO 是不错的选择。
372 0
|
存储 设计模式 SQL
实体类(VO,DO,DTO,PO)的划分
实体类(VO,DO,DTO,PO)的划分
989 0
|
安全 Java Maven
PO VO DTO 转换神器替代BeanUtils 了(一)
PO VO DTO 转换神器替代BeanUtils 了
194 0
|
Java Spring
PO VO DTO 转换神器替代BeanUtils 了(三)
PO VO DTO 转换神器替代BeanUtils 了
187 0