import org.springframework.validation.annotation.Validated;
import javax.validation.constraints.NotBlank;
@Validated
@RestController
@Api(tags = "任务菜单")
@RequestMapping("/taskMenu")
public class TaskMenuController {
@GetMapping("/nextTask")
@ResponseBody
public CommonResult getNextStep(@NotBlank(message = "actId不能为空") String actId,
@NotBlank(message = "processDefinitionId不能为空") String processDefinitionId){
return taskMenuService.getNextStep(actId, processDefinitionId);
}
/**
* 根据关键字查询列表
* @param screenParams
* @return
*/
@ApiOperation(value = "筛选")
@RequestMapping(value = "/list/noUuap", method = RequestMethod.POST)
@ResponseBody
public CommonResult getTaskListByKey(@Validated @RequestBody ScreenParams screenParams) {
PageResult taskResults = taskService.getListByKey(screenParams);
return CommonResult.success(taskResults);
}
// 将校验的错误信息返回到前端,BindingResult 这个对象的作用是将所有的异常信息存起来。
@ResponseBody
@RequestMapping("/test4")
public Map<String, Object> test5(@Validated User user, BindingResult result) {
Map<String, Object> model = null;
if (result.hasErrors()) {
model = result.getModel();
}
System.out.println(user);
return model;
}
}
如果方法上的RequestMapping注解没有设置method属性,则get和post请求默认都可以访问。
Validated的基础API
@Null 限制只能为null
@NotNull 限制必须不为null
@AssertFalse 限制必须为false
@AssertTrue 限制必须为true
@DecimalMax(value) 限制必须为一个不大于指定值的数字
@DecimalMin(value) 限制必须为一个不小于指定值的数字
@Digits(integer,fraction) 限制必须为一个小数,且整数部分的位数不能超过integer,小数部分的位数不能超过fraction
@Future 限制必须是一个将来的日期
@Max(value) 限制必须为一个不大于指定值的数字
@Min(value) 限制必须为一个不小于指定值的数字
@Past 限制必须是一个过去的日期
@Pattern(value) 限制必须符合指定的正则表达式
@Size(max,min) 限制字符长度必须在min到max之间
@Past 验证注解的元素值(日期类型)比当前时间早
@NotEmpty 验证注解的元素值不为null且不为空(字符串长度不为0、集合大小不为0)
@
- NotBlank 验证注解的元素值不为空(不为null、去除首位空格后长度为0),不同于@NotEmpty,@NotBlank只应用于字符串且在比较时会去除字符串的空格
@Email 验证注解的元素值是Email,也可以通过正则表达式和flag指定自定义的email格式