SpringBoot 入門(mén)教程之引入數(shù)據(jù)傳輸層的方法
我們現(xiàn)在操作的數(shù)據(jù)直接就使用了實(shí)體類(lèi),假如我們輸出的用戶(hù)對(duì)象需要包含用戶(hù)擁有的權(quán)限列表,那么我們?cè)趺捶庋b呢?
直接封裝進(jìn)實(shí)體類(lèi)中顯然不行,因?yàn)閷?shí)體類(lèi)的職責(zé)就是提供與數(shù)據(jù)庫(kù)表字段一一對(duì)應(yīng)的映射關(guān)系,所以我們還需要封裝出一層數(shù)據(jù)傳輸層 DTO(Data Transfer Object),通過(guò)它暴露給外部,這樣我們就能高度定制化我們需要輸出的數(shù)據(jù)而不會(huì)影響到實(shí)體類(lèi)。
在項(xiàng)目中創(chuàng)建 dto 目錄,新建 UserDto.java 文件:
package com.foxescap.wxbox.dto;
import lombok.Data;
import java.time.LocalDateTime;
/**
* @author xfly
*/
@Data
public class UserDto {
private String username;
private LocalDateTime expiredAt;
private LocalDateTime createdAt;
private List<RoleDto> roles;
}
結(jié)構(gòu)看上去基本和對(duì)應(yīng)的實(shí)體類(lèi)非常相似,職責(zé)區(qū)別就是:
• 我不想暴露出去的字段可以直接不聲明。
• 我可以加如其他的 DTO 作為其中的屬性,如上所示。
對(duì)應(yīng)我們的 Service 層就需要在拿到實(shí)體類(lèi)對(duì)象后轉(zhuǎn)換成 DTO 對(duì)象:
public UserDto findByUsername(String username) {
var user = lambdaQuery().eq(User::getUsername, username).one();
var userDto = new UserDto();
userDto.setUsername(user.getUsername());
userDto.setExpiredAt(user.getExpiredAt());
userDto.setCreatedAt(user.getCreatedAt());
return userDto;
}
這里你會(huì)發(fā)現(xiàn),這個(gè)轉(zhuǎn)換的過(guò)程特別難受,就像寫(xiě) Getter 和 Setter 方法一樣,寫(xiě)多了要吐了。
我會(huì)寫(xiě)吐別人也一樣會(huì)寫(xiě)吐,然后就會(huì)有輪子造出來(lái),modelmapper就是解決這樣需求的一個(gè)用的人比較多的輪子。
在 pom.xml 項(xiàng)目配置文件中的 dependencies 中加入 modelmapper 依賴(lài):
<dependency> <groupId>org.modelmapper</groupId> <artifactId>modelmapper</artifactId> <version>2.3.7</version> </dependency>
然后在 config 目錄中的 WebMvcConfig.java 文件中注入這個(gè)對(duì)象:
@Bean
public ModelMapper modelMapper() {
ModelMapper modelMapper = new ModelMapper();
modelMapper.getConfiguration().setFullTypeMatchingRequired(true);
modelMapper.getConfiguration().setMatchingStrategy(MatchingStrategies.STRICT);
return modelMapper;
}
我們這個(gè)時(shí)候再來(lái)改造一下 findByUsername 方法:
private final ModelMapper modelMapper;
public UserService(ModelMapper modelMapper) {
this.modelMapper = modelMapper;
}
public UserDto findByUsername(String username) {
var user = lambdaQuery().eq(User::getUsername, username).one();
return modelMapper.map(user, UserDto.class);
}
到此這篇關(guān)于SpringBoot 入門(mén)教程之引入數(shù)據(jù)傳輸層的方法的文章就介紹到這了,更多相關(guān)SpringBoot 引入數(shù)據(jù)傳輸層內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mybatis查詢(xún)時(shí)數(shù)據(jù)丟失的問(wèn)題及解決
Mybatis查詢(xún)時(shí)數(shù)據(jù)丟失的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
Spring Boot 整合 Apache Dubbo的示例代碼
Apache Dubbo是一款高性能、輕量級(jí)的開(kāi)源 Java RPC 框架,這篇文章主要介紹了Spring Boot 整合 Apache Dubbo的方法,本文通過(guò)示例說(shuō)明給大家講解的非常詳細(xì),需要的朋友可以參考下2021-07-07
如何基于java隨機(jī)獲取不重復(fù)數(shù)值
這篇文章主要介紹了如何基于java隨機(jī)獲取不重復(fù)數(shù)值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
MyBatis-Plus中使用EntityWrappe進(jìn)行列表數(shù)據(jù)倒序設(shè)置方式
這篇文章主要介紹了MyBatis-Plus中使用EntityWrappe進(jìn)行列表數(shù)據(jù)倒序設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
詳解springboot+mybatis-plue實(shí)現(xiàn)內(nèi)置的CRUD使用詳情
這篇文章主要介紹了詳解springboot+mybatis-plue實(shí)現(xiàn)內(nèi)置的CRUD使用詳情,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
快速解決跨域請(qǐng)求問(wèn)題:jsonp和CORS
這篇文章主要介紹了快速解決跨域請(qǐng)求問(wèn)題:jsonp和CORS,涉及jsonp和CORS的介紹,分享了前端 jQuery 寫(xiě)法,后端 SpringMVC 配置,后端非 SpringMVC 配置等相關(guān)內(nèi)容,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-11-11

