###1. DTO的使用
如果你的controller代码写成这样
@RequestMapping("/user") public List query(@RequestParam String username, @RequestParam String password, @RequestParam int age){ Listusers = 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)); Listusers = 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 自定义注解简便开发