美文网首页Spring Boot首页推荐Java学习笔记
如何用 SpringBoot 优雅的写代码

如何用 SpringBoot 优雅的写代码

作者: FantJ | 来源:发表于2018-03-27 21:44 被阅读1265次

    1. DTO的使用

    如果你的controller代码写成这样

        @RequestMapping("/user")
        public List query(@RequestParam String username,
                          @RequestParam String password,
                          @RequestParam int age){
            List<User> users = new ArrayList<>();
            users.add(new User());
            users.add(new User());
            users.add(new User());
            return users;
        }
    

    那你就需要了解一下什么是DTO了。

    用DTO后的代码

        @RequestMapping("/user")
        public List query(UserQueryCondition condition){
    
            System.out.println(ReflectionToStringBuilder.toString(condition, ToStringStyle.DEFAULT_STYLE));
            List<User> users = new ArrayList<>();
            users.add(new User());
            users.add(new User());
            users.add(new User());
            return users;
        }
    

    2. 如何使用PageAble设置默认分页属性

    你是不是还是在方法体里声明Pageable对象固定属性呢?
    更优雅的在这里:
    @PageableDefault(page = 2,size = 7,sort = "username,asc")Pageable pageable

    3. 如何再@RequestMapping注解上写正则

    @RequestMapping("/user/{id:\\d+}") id只能是数字

    4. @JsonView注解自定义返回内容

    比如User类有两个属性,一个username一个password。
    我们想在controller返回里,返回User实体的时候不返回password属性。

    4.1 设置视图

    首先需要在实体类里声明两个接口

        public interface UserSimpleView{};
        public interface UserDetailView extends UserSimpleView{};
    

    然后,在一定要显示的字段的get方法上添加@JsonView(UserSimpleView.class)注解。
    在不一定要显示的字段的get方法上添加@JsonView(UserDetailView .class)注解。
    User.java 完整代码

    public class User {
    
    //    jsonView 设置视图
        public interface UserSimpleView{};
        public interface UserDetailView extends UserSimpleView{};
    
        private String useranme;
        private String password;
    
        @JsonView(UserSimpleView.class)
        public String getUseranme() {
            return useranme;
        }
    
        public void setUseranme(String useranme) {
            this.useranme = useranme;
        }
    
        @JsonView(UserDetailView.class)
        public String getPassword() {
            return password;
        }
    
        public void setPassword(String password) {
            this.password = password;
        }
    }
    

    注意getUseranme方法上的注解和getPassword上注解的不同。

    4.2 将实体类的get方法上的注解和Controller里相对应

    如果controller只想返回username字段,则

        @RequestMapping("/user/{id:\\d+}")
        @JsonView(User.UserSimpleView.class)
        public User getInfo(@PathVariable int id){
            User user = new User();
            user.setUseranme("FantJ");
            return user;
        }
    

    如果想返回全部的User属性信息,则

        @RequestMapping("/user/{id:\\d+}")
        @JsonView(User.UserDetailView.class)
        public User getInfo(@PathVariable int id){
            User user = new User();
            user.setUseranme("FantJ");
            return user;
        }
    

    上面这个controller方法,我们看到@JsonView(User.UserDetailView.class)所以它会。如果变成返回全部的User属性信息@JsonView(User.UserSimpleView.class),它就只返回username字段信息。因为User类和Controller类中@JsonView注解一一对应。

    5. 判断某个字段不为空

    我们都知道,post方法,需要用@RequestBody接收实体类信息。如果我们再方法里判断某个属性是否为空然后再抛错,必然增加代码量,不美观。所以我们可以配合几个注解来达到我们的要求。

    5.1 首先在实体类字段上添加注解@NotBlank
        @NotBlank  //不为空的注解
        private String password;
    
    5.2 在Controller里的@RequestBody前加注解@Valid
    @PostMapping("/user")
        public User create(@Valid @RequestBody User user){}
    

    但是光这两个注解作用下,如果密码出现了空值,程序会直接报错,我们希望程序可以正常运行,然后把报错信息打印出来就可以,于是我们还需要加一个类。BindingResult

    5.3 添加BindingResult参数
        @PostMapping("/user")
        public User create(@Valid @RequestBody User user, BindingResult errors){}
    

    那如何获取错误信息呢?看下面的完整代码。

    5.4 完整代码
        @PostMapping("/user")
        public User create(@Valid @RequestBody User user, BindingResult errors){
            user.setId("1");
            //打印错误信息
            if (errors.hasErrors()){
                errors.getAllErrors().stream().forEach(p-> System.out.println(p.getDefaultMessage()));
            }
            System.out.println(user.getId());
            System.out.println(user.getUseranme());
            System.out.println(user.getPassword());
            return user;
        }
    

    但是你一看控制台打印信息你会发现may not be empty,你都不知道是什么字段为空报错的,我们我们把字段信息打印出来。但是又显得代码很长。所以我们可以用@NotBlank的message属性来自定义message。
    除了@NotBlank外,还有一些类似常用的注解。

    • @NotNull 值不能为空
    • @NotEmpty 字符串不能为空,集合不能为空
    • @Range(min=,max=) 数字必须大于min小鱼max
    • @Max(value=) 设置最大值同理还有 @Min(value=)
    • @Email 字符必须是Email类型
    • @Length(min= ,max= ) 字符串长度设置
    • @URL 字符串是url

    6 自定义注解简便开发

    介绍下我的所有文集:

    流行框架

    SpringCloud
    springboot
    nginx
    redis

    底层实现原理:

    Java NIO教程
    Java reflection 反射详解
    Java并发学习笔录
    Java Servlet教程
    jdbc组件详解
    Java NIO教程
    Java语言/版本 研究

    相关文章

      网友评论

      本文标题:如何用 SpringBoot 优雅的写代码

      本文链接:https://www.haomeiwen.com/subject/cdiqcftx.html