# param-validation **Repository Path**: yuygoi/param-validation ## Basic Information - **Project Name**: param-validation - **Description**: No description available - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-06-04 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # param-validation #### 介绍 param-validation是一个给SpringMVC、SpringWebFlux提供不需要Vo对象的Json参数校验工具, 并提供WebFlux-form-data参数注入校验, 无需担心WebFlux无法获取请求体参数坑爹的问题 #### 使用说明 1. 使用@EnableFranklinValidationAll开启Json参数校验+WebFlux-Form-Data(URL encode)参数校验,参数注入 2. 使用@EnableWebFluxFormDataValidation仅开启WebFlux-Form-Data(URL encode)参数校验,参数注入 3. 使用@EnableJsonValidation仅开启Json参数校验 ```java //Json参数校验示例 //使用@NotNullForMap @PostMapping("/1") @NotNullForMap(params = { @ParamCheck(value = "personList",type = List.class,subParams = { @ParamCheckSub("id"), @ParamCheckSub("name"), @ParamCheckSub(value = "birth",type = Date.class,pattern = "yyyy-MM-dd",message = "生日错误"), }), @ParamCheck(value = "person",type = Map.class,subParams = { @ParamCheckSub("id"), @ParamCheckSub("name"), @ParamCheckSub(value = "birth",type = Date.class,pattern = "yyyy-MM-dd",message = "生日错误"), }) }) public String test1(@RequestBody Map param){ return param.toString(); } //WebFluxFormData参数注入校验示例 @PostMapping("/3") public Map test3( @ParamCheck(value = "birth",required = false,type = Date.class,pattern = "yyyy-MM-dd")String birth, @ParamCheck(value = "name",required = false)String name, @ParamCheck(value = "age",required = false,pattern = "[0-9]+")String age, @ParamCheck(value = "password",required = false)String password, @ParamCheck(value = "sign",required = false)String sign, @ParamCheck("id")List id, @ParamCheck("id1")List id1, @ParamCheck("id2")List id2, @ParamCheck("id3")List id3, @ParamCheck("id4")List id4, @ParamCheck("id5")List id5, @ParamCheck("id6")List id6, @ParamCheck("id7")Integer id7 ){ Map map = new HashMap<>(); map.put("birth",birth); map.put("name",name); map.put("age",age); map.put("password",password); map.put("sign",sign); map.put("id",id); map.put("id1",id1); map.put("id2",id2); map.put("id3",id3); map.put("id4",id4); map.put("id5",id5); map.put("id6",id6); map.put("id7",id7); return map; } ``` ​ 4.传递多个同名参数时请使用List、Set(去重)接收,默认为String类型,若集合中需要其它数据类型请参考如下例子: ```java @PostMapping("/6") public List test5(@ParamCheck(value = "id")List id){ return id; } ``` ![image-20200617140532231][id] [id]: 5.使用正则表达式,只需在pattern中设置即可,当需要验证日期格式时,指定type = Date.class,并指定需要的格式即可: 使用集合的情况下,所有元素都会进行校验 ```java //一般正则 @PostMapping("/6") public List test5(@ParamCheck(value = "id",pattern = "^[1-9]\\d*$")List id){ return id; } //校验日期 @PostMapping("/5") public String test5(@ParamCheck(value = "id",required = true,pattern = "yyyy-MM-dd",type = Date.class)String id){ return id; } ``` 6.自定义出现校验错误返回的Vo对象: 实现JsonResponse接口,注入Bean容器,并添加@Response(type = 注明VO.class) 框架处理完成的错误信息会返回一个String解析这个String即可 ```java @Component @Response(type = NewJsonMessage.class) public class NewJsonMessageJsonResponse extends BaseController implements JsonResponse { //参数错误会调用此方法 @Override public NewJsonMessage response(String input) { return JsonMsgContent(HttpStatusFly.ERROR_PARAMETER_INACCURACY,input.split(Constants.COMMA)[1]); } //出现其它错误会调用此方法 @Override public NewJsonMessage defaultResponse(Class... classes) { return JsonMsgContent(HttpStatusFly.SERVICE_ERROR); } } ``` .[![](https://jitpack.io/v/com.gitee.yuygoi/param-validation.svg)](https://jitpack.io/#com.gitee.yuygoi/param-validation)