设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

腾讯工作近十年大佬:不是我打击你!你可能真的不会写Java(4)

发布时间:2019-07-01 16:18 所属栏目:21 来源:程序员小姐
导读:看了这部分代码以后,你可能会问,那逆向转化会有什么用呢?其实我们有很多小的业务需求中,入参和出参是一样的,那么我们变可以轻松的进行转化,我将上边所提到的 UserInputDTO 和 UserOutputDTO 都转成 UserDTO 展

看了这部分代码以后,你可能会问,那逆向转化会有什么用呢?其实我们有很多小的业务需求中,入参和出参是一样的,那么我们变可以轻松的进行转化,我将上边所提到的 UserInputDTO 和 UserOutputDTO 都转成 UserDTO 展示给大家。

DTO:

  1. public class UserDTO { 
  2.  private String username; 
  3.  private int age; 
  4.  public String getUsername() { 
  5.  return username; 
  6.  } 
  7.  public void setUsername(String username) { 
  8.  this.username = username; 
  9.  } 
  10.  public int getAge() { 
  11.  return age; 
  12.  } 
  13.  public void setAge(int age) { 
  14.  this.age = age; 
  15.  } 
  16.  public User convertToUser(){ 
  17.  UserDTOConvert userDTOConvert = new UserDTOConvert(); 
  18.  User convert = userDTOConvert.convert(this); 
  19.  return convert; 
  20.  } 
  21.  public UserDTO convertFor(User user){ 
  22.  UserDTOConvert userDTOConvert = new UserDTOConvert(); 
  23.  UserDTO convert = userDTOConvert.reverse().convert(user); 
  24.  return convert; 
  25.  } 
  26.  private static class UserDTOConvert extends Converter<UserDTO, User> { 
  27.  @Override 
  28.  protected User doForward(UserDTO userDTO) { 
  29.  User user = new User(); 
  30.  BeanUtils.copyProperties(userDTO,user); 
  31.  return user; 
  32.  } 
  33.  @Override 
  34.  protected UserDTO doBackward(User user) { 
  35.  UserDTO userDTO = new UserDTO(); 
  36.  BeanUtils.copyProperties(user,userDTO); 
  37.  return userDTO; 
  38.  } 
  39.  } 

API:

  1. @PostMapping 
  2.  public UserDTO addUser(UserDTO userDTO){ 
  3.  User user = userDTO.convertToUser(); 
  4.  User saveResultUser = userService.addUser(user); 
  5.  UserDTO result = userDTO.convertFor(saveResultUser); 
  6.  return result; 
  7.  } 

当然,上述只是表明了转化方向的正向或逆向,很多业务需求的出参和入参的 DTO 对象是不同的,那么你需要更明显的告诉程序:逆向是无法调用的:

  1. private static class UserDTOConvert extends Converter<UserDTO, User> { 
  2.  @Override 
  3.  protected User doForward(UserDTO userDTO) { 
  4.  User user = new User(); 
  5.  BeanUtils.copyProperties(userDTO,user); 
  6.  return user; 
  7.  } 
  8.  @Override 
  9.  protected UserDTO doBackward(User user) { 
  10.  throw new AssertionError("不支持逆向转化方法!"); 
  11.  } 
  12.  } 

看一下 doBackward 方法,直接抛出了一个断言异常,而不是业务异常,这段代码告诉代码的调用者,这个方法不是准你调用的,如果你调用,我就”断言”你调用错误了。

关于异常处理的更详细介绍,可以参考我之前的文章:如何优雅的设计 Java 异常(http://lrwinx.github.io/2016/04/28/%E5%A6%82%E4%BD%95%E4%BC%98%E9%9B%85%E7%9A%84%E8%AE%BE%E8%AE%A1java%E5%BC%82%E5%B8%B8/) ,应该可以帮你更好的理解异常。

bean 的验证

如果你认为我上边写的那个添加用户 API 写的已经非常完美了,那只能说明你还不是一个优秀的程序员。我们应该保证任何数据的入参到方法体内都是合法的。

为什么要验证

很多人会告诉我,如果这些 API 是提供给前端进行调用的,前端都会进行验证啊,你为什还要验证?

其实答案是这样的,我从不相信任何调用我 API 或者方法的人,比如前端验证失败了,或者某些人通过一些特殊的渠道(比如 Charles 进行抓包),直接将数据传入到我的 API,那我仍然进行正常的业务逻辑处理,那么就有可能产生脏数据!

“对于脏数据的产生一定是致命”,这句话希望大家牢记在心,再小的脏数据也有可能让你找几个通宵!

jsr 303验证

hibernate 提供的 jsr 303 实现,我觉得目前仍然是很优秀的,具体如何使用,我不想讲,因为谷歌上你可以搜索出很多答案!

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读