SpringBoot如何实现数据传输层引入教程?
- 内容介绍
- 相关推荐
本文共计938个文字,预计阅读时间需要4分钟。
在直接使用实体类操作数据时,若用户对象需要包含权限列表,封装的方式如下:
为了封装权限信息,我们可以创建一个用户类,其中包含权限列表。这样,用户对象不仅包含基本信息,还包含其权限。封装的目的是为了隐藏内部实现细节,提高代码的可维护性和可扩展性。
javapublic class User { private String username; private List permissions;
public User(String username, List permissions) { this.username=username; this.permissions=permissions; }
// Getters and Setters public String getUsername() { return username; }
public void setUsername(String username) { this.username=username; }
public List getPermissions() { return permissions; }
public void setPermissions(List permissions) { this.permissions=permissions; }}
通过这种方式,用户对象的权限管理被封装在用户类内部,外部访问时只需通过用户对象的方法来获取或修改权限列表,而不直接操作权限列表。这样做既保持了对象的封装性,也便于未来对权限管理功能的扩展和修改。
我们现在操作的数据直接就使用了实体类,假如我们输出的用户对象需要包含用户拥有的权限列表,那么我们怎么封装呢?
直接封装进实体类中显然不行,因为实体类的职责就是提供与数据库表字段一一对应的映射关系,所以我们还需要封装出一层数据传输层 DTO(Data Transfer Object),通过它暴露给外部,这样我们就能高度定制化我们需要输出的数据而不会影响到实体类。
在项目中创建 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; }
结构看上去基本和对应的实体类非常相似,职责区别就是:
• 我不想暴露出去的字段可以直接不声明。
• 我可以加如其他的 DTO 作为其中的属性,如上所示。
对应我们的 Service 层就需要在拿到实体类对象后转换成 DTO 对象:
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; }
这里你会发现,这个转换的过程特别难受,就像写 Getter 和 Setter 方法一样,写多了要吐了。
我会写吐别人也一样会写吐,然后就会有轮子造出来,modelmapper就是解决这样需求的一个用的人比较多的轮子。
在 pom.xml 项目配置文件中的 dependencies 中加入 modelmapper 依赖:
<dependency> <groupId>org.modelmapper</groupId> <artifactId>modelmapper</artifactId> <version>2.3.7</version> </dependency>
然后在 config 目录中的 WebMvcConfig.java 文件中注入这个对象:
@Bean public ModelMapper modelMapper() { ModelMapper modelMapper = new ModelMapper(); modelMapper.getConfiguration().setFullTypeMatchingRequired(true); modelMapper.getConfiguration().setMatchingStrategy(MatchingStrategies.STRICT); return modelMapper; }
我们这个时候再来改造一下 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); }
到此这篇关于SpringBoot 入门教程之引入数据传输层的方法的文章就介绍到这了,更多相关SpringBoot 引入数据传输层内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!
本文共计938个文字,预计阅读时间需要4分钟。
在直接使用实体类操作数据时,若用户对象需要包含权限列表,封装的方式如下:
为了封装权限信息,我们可以创建一个用户类,其中包含权限列表。这样,用户对象不仅包含基本信息,还包含其权限。封装的目的是为了隐藏内部实现细节,提高代码的可维护性和可扩展性。
javapublic class User { private String username; private List permissions;
public User(String username, List permissions) { this.username=username; this.permissions=permissions; }
// Getters and Setters public String getUsername() { return username; }
public void setUsername(String username) { this.username=username; }
public List getPermissions() { return permissions; }
public void setPermissions(List permissions) { this.permissions=permissions; }}
通过这种方式,用户对象的权限管理被封装在用户类内部,外部访问时只需通过用户对象的方法来获取或修改权限列表,而不直接操作权限列表。这样做既保持了对象的封装性,也便于未来对权限管理功能的扩展和修改。
我们现在操作的数据直接就使用了实体类,假如我们输出的用户对象需要包含用户拥有的权限列表,那么我们怎么封装呢?
直接封装进实体类中显然不行,因为实体类的职责就是提供与数据库表字段一一对应的映射关系,所以我们还需要封装出一层数据传输层 DTO(Data Transfer Object),通过它暴露给外部,这样我们就能高度定制化我们需要输出的数据而不会影响到实体类。
在项目中创建 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; }
结构看上去基本和对应的实体类非常相似,职责区别就是:
• 我不想暴露出去的字段可以直接不声明。
• 我可以加如其他的 DTO 作为其中的属性,如上所示。
对应我们的 Service 层就需要在拿到实体类对象后转换成 DTO 对象:
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; }
这里你会发现,这个转换的过程特别难受,就像写 Getter 和 Setter 方法一样,写多了要吐了。
我会写吐别人也一样会写吐,然后就会有轮子造出来,modelmapper就是解决这样需求的一个用的人比较多的轮子。
在 pom.xml 项目配置文件中的 dependencies 中加入 modelmapper 依赖:
<dependency> <groupId>org.modelmapper</groupId> <artifactId>modelmapper</artifactId> <version>2.3.7</version> </dependency>
然后在 config 目录中的 WebMvcConfig.java 文件中注入这个对象:
@Bean public ModelMapper modelMapper() { ModelMapper modelMapper = new ModelMapper(); modelMapper.getConfiguration().setFullTypeMatchingRequired(true); modelMapper.getConfiguration().setMatchingStrategy(MatchingStrategies.STRICT); return modelMapper; }
我们这个时候再来改造一下 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); }
到此这篇关于SpringBoot 入门教程之引入数据传输层的方法的文章就介绍到这了,更多相关SpringBoot 引入数据传输层内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

