1 import java.io.FileInputStream; 2 import java.io.FileNotFoundException; 3 import java.io.InputStream; 4 5 import org.springframework.util.Assert; 6 7 /** 8 * ClassName: AssertUtils 9 * @Description <描述> 方法入參檢測工具類 10 * Web 應用在接受表單提交的數據后都需要對其進行合法性檢查,如果表單數據不合法,請求將被駁回。 11 * 類似的,當我們在編寫類的方法時,也常常需要對方法入參進行合法性檢查,如果入參不符合要求,方法將通過拋出異常的方式拒絕后續處理 12 * @author wang 13 * @since 2019年2月18日 下午4:46:52 14 */ 15 public class AssertUtils { 16 17 static{ 18 /*舉一個例子: 19 * 有一個根據文件名獲取輸入流的方法:InputStream getData(String file), 20 * 為了使方法能夠成功執行,必須保證 file 入參不能為 null 或空白字符,否則根本無須進行后繼的處理。 21 * 這時方法的編寫者通常會在方法體的最前面編寫一段對入參進行檢測的代碼,如下所示: 22 */ 23 } 24 25 public InputStream getData(String file) throws FileNotFoundException { 26 if (file == null || file.length() == 0 || file.replaceAll("s", "").length() == 0) { 27 throw new IllegalArgumentException("file入參不是有效的文件地址"); 28 } 29 System.out.println("類似以上檢測方法入參的代碼是非常常見,但是在每個方法中都使用手工編寫檢測邏輯的方式並不是一個好主意。閱讀 Spring 源碼,您會發現 Spring 采用一個 org.springframework.util.Assert 通用類完成這一任務。"); 30 return new FileInputStream(file); 31 } 32 33 /** 34 * Assert 翻譯為中文為“斷言”,使用過 JUnit 的讀者都熟知這個概念,它斷定某一個實際的運行值和預期想一樣,否則就拋出異常。 35 * Spring 對方法入參的檢測借用了這個概念,其提供的 Assert 類擁有眾多按規則對方法入參進行斷言的方法,可以滿足大部分方法入參檢測的要求。 36 * 這些斷言方法在入參不滿足要求時就會拋出 IllegalArgumentException。 37 * 下面,我們來認識一下 Assert 類中的常用斷言方法: 38 */ 39 40 //斷言方法 說明 41 /* 42 notNull(Object object) //當 object 不為 null 時拋出異常, 43 notNull(Object object, String message) //方法允許您通過 message 定制異常信息。和 notNull() 方法斷言規則相反的方法是 44 isNull(Object object)/isNull(Object object, String message),//它要求入參一定是 null; 45 isTrue(boolean expression) / isTrue(boolean expression, String message) //當 expression 不為 true 拋出異常; 46 notEmpty(Collection collection) / notEmpty(Collection collection, String message) //當集合未包含元素時拋出異常。 47 notEmpty(Map map) / notEmpty(Map map, String message) 和 notEmpty(Object[] array, String message) / notEmpty(Object[] array, String message) //分別對 Map 和 Object[] 類型的入參進行判斷; 48 hasLength(String text) / hasLength(String text, String message) // 當 text 為 null 或長度為 0 時拋出異常; 49 hasText(String text) / hasText(String text, String message) //text 不能為 null 且必須至少包含一個非空格的字符,否則拋出異常; 50 isInstanceOf(Class clazz, Object obj) / isInstanceOf(Class type, Object obj, String message) // 如果 obj 不能被正確造型為 clazz 指定的類將拋出異常; 51 isAssignable(Class superType, Class subType) / isAssignable(Class superType, Class subType, String message) //subType 必須可以按類型匹配於 superType,否則將拋出異常; 52 */ 53 54 //使用 Assert 斷言類可以簡化方法入參檢測的代碼,如 InputStream getData(String file) 在應用 Assert 斷言類后,其代碼可以簡化為以下的形式: 55 public InputStream getDataAssert(String file){ 56 Assert.hasText(file, "file入參不是有效的文件地址"); 57 //① 使用 Spring 斷言類進行方法入參檢測 58 return null; 59 } 60 }