這種方式適用於接收較多的參數,且其中有些參數是不能為空的,去校驗不能為空的參數。
1、接收綁定請求參數到
@ResponseBody @RequestMapping(value = "saveContent", method = RequestMethod.POST) public ContentResult saveContent(CpContent cpContent) { ContentResult result = new ContentResult(); // 必填參數校驗 boolean pass = BeanUtil.paramCheck(cpContent); if (!pass) { result.fail(ResponseEnum.ERROR_PARAM.getCode(), ResponseEnum.ERROR_PARAM.getMsg()); return result; } }
2、DTO中不能為空的參數加上自定義注解標記
@ParamCheck(emptyAble= CheckEnum.NOTEMPTY) private String title;
3、自定義注解
/** * 參數校驗注解 * * @author yangyongjie * @date 2020/5/14 * @desc */ @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface ParamCheck { /** * 是否允許為空 */ CheckEnum emptyAble() default CheckEnum.EMPTY; } public enum CheckEnum { NOTEMPTY, EMPTY }
4、校驗工具方法
/** * 判斷參數是否為空 * * @param obj * @return */ public static boolean paramCheck(Object obj) { try { Class<?> clazz = obj.getClass(); Field[] fields = clazz.getDeclaredFields(); for (Field field : fields) { field.setAccessible(true); ParamCheck paramCheck = field.getAnnotation(ParamCheck.class); if (paramCheck != null) { //非空校驗,后續若需增加校驗類型,應抽離 if (paramCheck.emptyAble() == CheckEnum.NOTEMPTY) { Object val = field.get(obj); if (val == null || "".equals(val.toString())) { return false; } } } } } catch (Exception ex) { LOGGER.info("Param verify error"); return false; } return true; }
