如何⽤SpringBoot优雅的写代码
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.String(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");
springboot框架的作用
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()){
}
System.out.Id());
System.out.Useranme());
System.out.Password());
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 ⾃定义注解简便开发
介绍下我的所有⽂集:
流⾏框架
底层实现原理:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。

发表评论