后端服务层在接收前端表单提交的数据后都需要对其进行合法性检查。如果表单数据不合法,请求将被驳回。如下:

if (name == null || name.equls("")) {  
    throw new IllegalArgumentException("参数错误!");  
}  

使用 Assert 断言类可以简化方法入参检测的代码,如 InputStream getData(String file) 在应用 Assert 断言类后,其代码可以简化为以下的形式:

Assert.hasText((name, "参数错误!");  

类似以上检测方法入参的代码是非常常见,但是在每个方法中都使用手工编写检测逻辑的方式并不是一个好主意。阅读 Spring 源码,您会发现 Spring 采用一个 org.springframework.util.Assert 通用类完成这一任务。

Assert 翻译为中文为“断言”,使用过 JUnit 的读者都熟知这个概念,它断定某一个实际的运行值和预期想一样,否则就抛出异常 。Spring 对方法入参的检测借用了这个概念,其提供的 Assert 类拥有众多按规则对方法入参进行断言的方法,可以满足大部分方法入参检测的要求。这些断言方法在入参不满足要求时就会抛出 IllegalArgumentException。下面,我们来认识一下 Assert 类中的常用断言方法:

断言方法 说明

notNull(Object object)

当 object 为 null 时抛出异常,notNull(Object object, String message) 方法允许您通过 message 定制异常信息。和 notNull() 方法断言规则相反的方法是 isNull(Object object)/isNull(Object object, String message),它要求入参一定是 null;

isTrue(boolean expression) / isTrue(boolean expression, String message)

当 expression 不为 true 抛出异常;

notEmpty(Collection collection) / notEmpty(Collection collection, String message)

当集合未包含元素时抛出异常。 notEmpty(Map map) / notEmpty(Map map, String message) 和 notEmpty(Object[] array, String message) / notEmpty(Object[] array, String message) 分别对 Map 和 Object[] 类型的入参进行判断;

hasLength(String text) / hasLength(String text, String message)

当 text 为 null 或长度为 0 时抛出异常;

hasText(String text) / hasText(String text, String message)

text 不能为 null 且必须至少包含一个非空格的字符,否则抛出异常;

isInstanceOf(Class clazz, Object obj) / isInstanceOf(Class type, Object obj, String message)

如果 obj 不能被正确造型为 clazz 指定的类将抛出异常;

isAssignable(Class superType, Class subType) / isAssignable(Class superType, Class subType, String message)

subType 必须可以按类型匹配于 superType,否则将抛出异常;

栗子

public class AssertTest {
    public static void main(String[] args) {
        Assert.notNull(null,"对象是空的");
        Assert.isNull(new Object(),"不是空的");
        Assert.isTrue(1==2,"不相等");
        Assert.isTrue(1==2);
        Assert.notEmpty(new String[]{},"空的1");
        Assert.notEmpty(new HashMap<String, String>(),"空的2");
        Assert.hasLength("","长度为0");
        Assert.hasText("","空的");
        Assert.isInstanceOf(String.class,new Object(),"类型不匹配");
        Assert.isAssignable(Object.class, String.class,"通过");
        Assert.isAssignable(String.class,Object.class, "不通过");
    }
}