在java的龐大體系中,其實有很多不錯的小工具,也就是我們平常說的:輪子
。
如果在我們的日常工作當中,能夠將這些輪子使用者,再配合一下idea的快捷鍵,可以極大得提升我們的開發效率。
今天我決定把一些壓箱底的小工具,分享給大家,希望對你有所幫助。
本文會分享17個我們日常工作中一定會用得到的小工具,主要內容如下:
首先出場的是java.util
包下的Collections
類,該類主要用於操作集合或者返回集合,我個人非常喜歡用它。
在工作中經常有對集合排序的需求。
看看使用Collections
工具是如何實現升序和降序的:
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
Collections.sort(list);//升序
System.out.println(list);
Collections.reverse(list);//降序
System.out.println(list);
執行結果:
[1, 2, 3]
[3, 2, 1]
有時候需要找出集合中的最大值
或者最小值
,這時可以使用Collections的max
和min
方法。例如:
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
Integer max = Collections.max(list);//獲取最大值
Integer min = Collections.min(list);//獲取最小值
System.out.println(max);
System.out.println(min);
執行結果:
3
1
我們都知道,java中的很多集合,比如:ArrayList、LinkedList、HashMap、HashSet等,都是執行緒不安全的。
換句話說,這些集合在多執行緒的環境中,新增資料會出現異常。
這時,可以用Collections的synchronizedxxx
方法,將這些執行緒不安全的集合,直接轉換成執行緒安全集合。例如:
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
List<Integer> integers = Collections.synchronizedList(list);//將ArrayList轉換成執行緒安全集合
System.out.println(integers);
它的底層會建立SynchronizedRandomAccessList
或者SynchronizedList
類,這兩個類的很多方法都會用synchronized
加鎖。
有時,我們在判空之後,需要返回空集合,就可以使用emptyList
方法,例如:
private List<Integer> fun(List<Integer> list) {
if (list == null || list.size() == 0) {
return Collections.emptyList();
}
//業務處理
return list;
}
binarySearch
方法提供了一個非常好用的二分查詢
功能,只用傳入指定集合和需要找到的key即可。例如:
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
int i = Collections.binarySearch(list, 3);//二分查詢
System.out.println(i );
執行結果:
2
為了防止後續的程式把某個集合的結果修改了,有時候我們需要把某個集合定義成不可修改的,使用Collections的unmodifiablexxx
方法就能輕鬆實現:
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
List<Integer> integers = Collections.unmodifiableList(list);
integers.add(4);
System.out.println(integers);
執行結果:
Exception in thread "main" java.lang.UnsupportedOperationException
at java.util.Collections$UnmodifiableCollection.add(Collections.java:1055)
at com.sue.jump.service.test1.UtilTest.main(UtilTest.java:19)
當然Collections工具類中還有很多常用的方法,在這裡就不一一介紹了,需要你自己去探索。
對集合操作,除了前面說的Collections
工具類之後,CollectionUtils
工具類也非常常用。
目前比較主流的是spring
的org.springframework.util
包下的CollectionUtils工具類。
和apache
的org.apache.commons.collections
包下的CollectionUtils工具類。
我個人更推薦使用apache的包下的CollectionUtils工具類,因為它的工具更多更全面。
舉個簡單的例子,spring
的CollectionUtils工具類沒有判斷集合不為空的方法。而apache
的CollectionUtils工具類卻有。
下面我們以apache
的CollectionUtils工具類為例,介紹一下常用方法。
通過CollectionUtils工具類的isEmpty
方法可以輕鬆判斷集合是否為空,isNotEmpty
方法判斷集合不為空。
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
if (CollectionUtils.isEmpty(list)) {
System.out.println("集合為空");
}
if (CollectionUtils.isNotEmpty(list)) {
System.out.println("集合不為空");
}
有時候我們需要對已有的兩個集合進行操作,比如取交集或者並集等。
List<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(3);
List<Integer> list2 = new ArrayList<>();
list2.add(2);
list2.add(4);
//獲取並集
Collection<Integer> unionList = CollectionUtils.union(list, list2);
System.out.println(unionList);
//獲取交集
Collection<Integer> intersectionList = CollectionUtils.intersection(list, list2);
System.out.println(intersectionList);
//獲取交集的補集
Collection<Integer> disjunctionList = CollectionUtils.disjunction(list, list2);
System.out.println(disjunctionList);
//獲取差集
Collection<Integer> subtractList = CollectionUtils.subtract(list, list2);
System.out.println(subtractList);
執行結果:
[1, 2, 3, 4]
[2]
[1, 3, 4]
[1, 3]
說句實話,對兩個集合的操作,在實際工作中用得挺多的,特別是很多批次的場景中。以前我們需要寫一堆程式碼,但沒想到有現成的輪子。
如果你引入com.google.guava
的pom檔案,會獲得很多好用的小工具。這裡推薦一款com.google.common.collect
包下的集合工具:Lists
。
它是在太好用了,讓我愛不釋手。
有時候,我們想建立一個空集合。這時可以用Lists的newArrayList
方法,例如:
List<Integer> list = Lists.newArrayList();
有時候,我們想給一個集合中初始化一些元素。這時可以用Lists的newArrayList方法,例如:
List<Integer> list = Lists.newArrayList(1, 2, 3);
執行結果:
[1, 2, 3]
如果你想將兩個集合做笛卡爾積
,Lists的cartesianProduct
方法可以幫你實現:
List<Integer> list1 = Lists.newArrayList(1, 2, 3);
List<Integer> list2 = Lists.newArrayList(4,5);
List<List<Integer>> productList = Lists.cartesianProduct(list1,list2);
System.out.println(productList);
執行結果:
[[1, 4], [1, 5], [2, 4], [2, 5], [3, 4], [3, 5]]
如果你想將一個大集合
分成若干個小集合
,可以使用Lists的partition
方法:
List<Integer> list = Lists.newArrayList(1, 2, 3, 4, 5);
List<List<Integer>> partitionList = Lists.partition(list, 2);
System.out.println(partitionList);
執行結果:
[[1, 2], [3, 4], [5]]
這個例子中,list有5條資料,我將list集合按大小為2,分成了3頁,即變成3個小集合。
這個是我最喜歡的方法之一,經常在專案中使用。
比如有個需求:現在有5000個id,需要呼叫批次使用者查詢介面,查出使用者資料。但如果你直接查5000個使用者,單次介面響應時間可能會非常慢。如果改成分頁處理,每次只查500個使用者,非同步呼叫10次介面,就不會有單次介面響應慢的問題。
如果我們想把某個集合轉換成另外一個介面,可以使用Lists的
transform
方法。例如:
List<String> list = Lists.newArrayList("a","b","c");
List<String> transformList = Lists.transform(list, x -> x.toUpperCase());
System.out.println(transformList);
將小寫字母轉換成了大寫字母。
Lists的有顛倒順序的方法reverse
。例如:
List<Integer> list = Lists.newArrayList(3, 1, 2);
List<Integer> reverseList = Lists.reverse(list);
System.out.println(reverseList);
執行結果:
[2, 1, 3]
list的原始順序是312,使用reverse
方法顛倒順序之後,變成了213。
Lists還有其他的好用的工具,我在這裡只是拋磚引玉,有興趣的朋友,可以仔細研究一下。
在jdk7
之後,提供了Objects
工具類,我們可以通過它操作物件。
在java中萬事萬物皆物件,物件的判空可以說無處不在。Objects的isNull
方法判斷物件是否為空,而nonNull
方法判斷物件是否不為空。例如:
Integer integer = new Integer(1);
if (Objects.isNull(integer)) {
System.out.println("物件為空");
}
if (Objects.nonNull(integer)) {
System.out.println("物件不為空");
}
如果我們想在物件為空時,丟擲空指標異常,可以使用Objects的requireNonNull
方法。例如:
Integer integer1 = new Integer(128);
Objects.requireNonNull(integer1);
Objects.requireNonNull(integer1, "引數不能為空");
Objects.requireNonNull(integer1, () -> "引數不能為空");
我們經常需要判斷兩個物件是否相等,Objects給我們提供了equals
方法,能非常方便的實現:
Integer integer1 = new Integer(1);
Integer integer2 = new Integer(1);
System.out.println(Objects.equals(integer1, integer2));
執行結果:
true
但使用這個方法有坑,比如例子改成:
Integer integer1 = new Integer(1);
Long integer2 = new Long(1);
System.out.println(Objects.equals(integer1, integer2));
執行結果:
false
具體原因不細說了,有興趣的小夥們可以看看我的另一篇文章《Objects.equals有坑》,裡面有非常詳細的講解。
如果你想獲取某個物件的hashCode,可以使用Objects的hashCode
方法。例如:
String str = new String("abc");
System.out.println(Objects.hashCode(str));
執行結果:
96354
Objects的內容先介紹到這裡,有興趣的小夥們,可以看看下面更多的方法:
在java中布林值,隨處可見。
如果你使用了布林的包裝類:Boolean
,總感覺有點麻煩,因為它有三種值:null
、true
、false
。我們在處理Boolean物件時,需要經常判空。
頭疼!!!
但如果使用BooleanUtils
類處理布林值,心情一下子就愉悅起來了。
如果你想判斷某個引數的值是true或false,可以直接使用isTrue
或isFalse
方法。例如:
Boolean aBoolean = new Boolean(true);
System.out.println(BooleanUtils.isTrue(aBoolean));
System.out.println(BooleanUtils.isFalse(aBoolean));
有時候,需要判斷某個引數不為true,即是null或者false。或者判斷不為false,即是null或者true。
可以使用isNotTrue
或isNotFalse
方法。例如:
Boolean aBoolean = new Boolean(true);
Boolean aBoolean1 = null;
System.out.println(BooleanUtils.isNotTrue(aBoolean));
System.out.println(BooleanUtils.isNotTrue(aBoolean1));
System.out.println(BooleanUtils.isNotFalse(aBoolean));
System.out.println(BooleanUtils.isNotFalse(aBoolean1));
執行結果:
false
true
true
true
如果你想將true轉換成數位1,false轉換成數位0,可以使用toInteger
方法:
Boolean aBoolean = new Boolean(true);
Boolean aBoolean1 = new Boolean(false);
System.out.println(BooleanUtils.toInteger(aBoolean));
System.out.println(BooleanUtils.toInteger(aBoolean1));
執行結果:
1
0
我們有時候需要將包裝類Boolean
物件,轉換成原始的boolean
物件,可以使用toBoolean
方法。例如:
Boolean aBoolean = new Boolean(true);
Boolean aBoolean1 = null;
System.out.println(BooleanUtils.toBoolean(aBoolean));
System.out.println(BooleanUtils.toBoolean(aBoolean1));
System.out.println(BooleanUtils.toBooleanDefaultIfNull(aBoolean1, false));
我們無需額外的判空了,而且還可以設定Boolean物件為空時返回的預設值。
BooleanUtils類的方法還有很多,有興趣的小夥伴可以看看下面的內容:
字串
(String)在我們的日常工作中,用得非常非常非常多。
在我們的程式碼中經常需要對字串判空,擷取字串、轉換大小寫、分隔字串、比較字串、去掉多餘空格、拼接字串、使用正規表示式等等。
如果只用String類提供的那些方法,我們需要手寫大量的額外程式碼,不然容易出現各種異常。
現在有個好訊息是:org.apache.commons.lang3
包下的StringUtils
工具類,給我們提供了非常豐富的選擇。
其實空字串,不只是null一種,還有""," ","null"等等,多種情況。
StringUtils給我們提供了多個判空的靜態方法,例如:
String str1 = null;
String str2 = "";
String str3 = " ";
String str4 = "abc";
System.out.println(StringUtils.isEmpty(str1));
System.out.println(StringUtils.isEmpty(str2));
System.out.println(StringUtils.isEmpty(str3));
System.out.println(StringUtils.isEmpty(str4));
System.out.println("=====");
System.out.println(StringUtils.isNotEmpty(str1));
System.out.println(StringUtils.isNotEmpty(str2));
System.out.println(StringUtils.isNotEmpty(str3));
System.out.println(StringUtils.isNotEmpty(str4));
System.out.println("=====");
System.out.println(StringUtils.isBlank(str1));
System.out.println(StringUtils.isBlank(str2));
System.out.println(StringUtils.isBlank(str3));
System.out.println(StringUtils.isBlank(str4));
System.out.println("=====");
System.out.println(StringUtils.isNotBlank(str1));
System.out.println(StringUtils.isNotBlank(str2));
System.out.println(StringUtils.isNotBlank(str3));
System.out.println(StringUtils.isNotBlank(str4));
執行結果:
true
true
false
false
=====
false
false
true
true
=====
true
true
true
false
=====
false
false
false
true
範例中的:isEmpty
、isNotEmpty
、isBlank
和isNotBlank
,這4個判空方法你們可以根據實際情況使用。
優先推薦使用
isBlank
和isNotBlank
方法,因為它會把" "
也考慮進去。
分隔字串是常見需求,如果直接使用String類的split方法,就可能會出現空指標異常。
String str1 = null;
System.out.println(StringUtils.split(str1,","));
System.out.println(str1.split(","));
執行結果:
null
Exception in thread "main" java.lang.NullPointerException
at com.sue.jump.service.test1.UtilTest.main(UtilTest.java:21)
使用StringUtils的split方法會返回null,而使用String的split方法會報指標異常。
給定一個字串,判斷它是否為純數位,可以使用isNumeric
方法。例如:
String str1 = "123";
String str2 = "123q";
String str3 = "0.33";
System.out.println(StringUtils.isNumeric(str1));
System.out.println(StringUtils.isNumeric(str2));
System.out.println(StringUtils.isNumeric(str3));
執行結果:
true
false
false
有時候,我們需要將某個集合的內容,拼接成一個字串,然後輸出,這時可以使用join
方法。例如:
List<String> list = Lists.newArrayList("a", "b", "c");
List<Integer> list2 = Lists.newArrayList(1, 2, 3);
System.out.println(StringUtils.join(list, ","));
System.out.println(StringUtils.join(list2, " "));
執行結果:
a,b,c
1 2 3
當然還有很多實用的方法,我在這裡就不一一介紹了。
很多時候,我們需要在程式碼中做判斷:如果不滿足條件,則拋異常。
有沒有統一的封裝呢?
其實spring
給我們提供了Assert
類,它表示斷言
。
斷言引數
是否空,如果不滿足條件,則直接拋異常。
String str = null;
Assert.isNull(str, "str必須為空");
Assert.isNull(str, () -> "str必須為空");
Assert.notNull(str, "str不能為空");
如果不滿足條件就會丟擲IllegalArgumentException
異常。
斷言集合
是否空,如果不滿足條件,則直接拋異常。
List<String> list = null;
Map<String, String> map = null;
Assert.notEmpty(list, "list不能為空");
Assert.notEmpty(list, () -> "list不能為空");
Assert.notEmpty(map, "map不能為空");
如果不滿足條件就會丟擲IllegalArgumentException
異常。
斷言是否滿足某個條件
,如果不滿足條件,則直接拋異常。
List<String> list = null;
Assert.isTrue(CollectionUtils.isNotEmpty(list), "list不能為空");
Assert.isTrue(CollectionUtils.isNotEmpty(list), () -> "list不能為空");
當然Assert類還有一些其他的功能,這裡就不多介紹了。
IO
流在我們日常工作中也用得比較多,儘管java已經給我們提供了豐富的API。
但我們不得不每次讀取檔案,或者寫入檔案之後,寫一些重複的的程式碼。手動在finally
程式碼塊中關閉流,不然可能會造成記憶體溢位
。
有個好訊息是:如果你使用org.apache.commons.io
包下的IOUtils
類,會節省大量的時間。
如果你想將某個txt檔案中的資料,讀取到字串當中,可以使用IOUtils類的toString
方法。例如:
String str = IOUtils.toString(new FileInputStream("/temp/a.txt"), StandardCharsets.UTF_8);
System.out.println(str);
如果你想將某個字串的內容,寫入到指定檔案當中,可以使用IOUtils類的write
方法。例如:
String str = "abcde";
IOUtils.write(str, new FileOutputStream("/temp/b.tx"), StandardCharsets.UTF_8);
如果你想將某個檔案中的所有內容,都拷貝到另一個檔案當中,可以使用IOUtils類的copy
方法。例如:
IOUtils.copy(new FileInputStream("/temp/a.txt"), new FileOutputStream("/temp/b.txt"));
如果你想將某個檔案中的內容,讀取位元組陣列中,可以使用IOUtils類的toByteArray
方法。例如:
byte[] bytes = IOUtils.toByteArray(new FileInputStream("/temp/a.txt"));
IOUtils類非常實用,感興趣的小夥們,可以看看下面內容。
MDC
是org.slf4j
包下的一個類,它的全稱是Mapped Diagnostic Context,我們可以認為它是一個執行緒安全的存放診斷紀錄檔的容器。
MDC的底層是用了ThreadLocal
來儲存資料的。
我們可以用它傳遞引數。
例如現在有這樣一種場景:我們使用RestTemplate
呼叫遠端介面時,有時需要在header
中傳遞資訊,比如:traceId,source等,便於在查詢紀錄檔時能夠串聯一次完整的請求鏈路,快速定位問題。
這種業務場景就能通過ClientHttpRequestInterceptor
介面實現,具體做法如下:
第一步,定義一個LogFilter攔截所有介面請求,在MDC中設定traceId:
public class LogFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
MdcUtil.add(UUID.randomUUID().toString());
System.out.println("記錄請求紀錄檔");
chain.doFilter(request, response);
System.out.println("記錄響應紀錄檔");
}
@Override
public void destroy() {
}
}
第二步,實現ClientHttpRequestInterceptor
介面,MDC中獲取當前請求的traceId,然後設定到header中:
public class RestTemplateInterceptor implements ClientHttpRequestInterceptor {
@Override
public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException {
request.getHeaders().set("traceId", MdcUtil.get());
return execution.execute(request, body);
}
}
第三步,定義設定類,設定上面定義的RestTemplateInterceptor
類:
@Configuration
public class RestTemplateConfiguration {
@Bean
public RestTemplate restTemplate() {
RestTemplate restTemplate = new RestTemplate();
restTemplate.setInterceptors(Collections.singletonList(restTemplateInterceptor()));
return restTemplate;
}
@Bean
public RestTemplateInterceptor restTemplateInterceptor() {
return new RestTemplateInterceptor();
}
}
其中MdcUtil其實是利用MDC工具在ThreadLocal中儲存和獲取traceId
public class MdcUtil {
private static final String TRACE_ID = "TRACE_ID";
public static String get() {
return MDC.get(TRACE_ID);
}
public static void add(String value) {
MDC.put(TRACE_ID, value);
}
}
當然,這個例子中沒有演示MdcUtil類的add方法具體調的地方,我們可以在filter中執行介面方法之前,生成traceId,呼叫MdcUtil類的add方法新增到MDC中,然後在同一個請求的其他地方就能通過MdcUtil類的get方法獲取到該traceId。
能使用MDC儲存traceId等引數的根本原因是,使用者請求到應用伺服器,Tomcat會從執行緒池中分配一個執行緒去處理該請求。
那麼該請求的整個過程中,儲存到MDC的ThreadLocal中的引數,也是該執行緒獨享的,所以不會有執行緒安全問題。
spring的org.springframework.util
包下的ClassUtils
類,它裡面有很多讓我們驚喜的功能。
它裡面包含了類和物件相關的很多非常實用的方法。
如果你想獲取某個物件的所有介面,可以使用ClassUtils的getAllInterfaces
方法。例如:
Class<?>[] allInterfaces = ClassUtils.getAllInterfaces(new User());
如果你想獲取某個類的包名,可以使用ClassUtils的getPackageName
方法。例如:
String packageName = ClassUtils.getPackageName(User.class);
System.out.println(packageName);
如果你想判斷某個類是否內部類,可以使用ClassUtils的isInnerClass
方法。例如:
System.out.println(ClassUtils.isInnerClass(User.class));
如果你想判斷物件是否代理物件,可以使用ClassUtils的isCglibProxy
方法。例如:
System.out.println(ClassUtils.isCglibProxy(new User()));
ClassUtils還有很多有用的方法,等待著你去發掘。感興趣的朋友,可以看看下面內容:
spring給我們提供了一個JavaBean
的工具類,它在org.springframework.beans
包下面,它的名字叫做:BeanUtils
。
讓我們一起看看這個工具可以帶給我們哪些驚喜。
曾幾何時,你有沒有這樣的需求:把某個物件中的所有屬性,都拷貝到另外一個物件中。這時就能使用BeanUtils的copyProperties
方法。例如:
User user1 = new User();
user1.setId(1L);
user1.setName("蘇三說技術");
user1.setAddress("成都");
User user2 = new User();
BeanUtils.copyProperties(user1, user2);
System.out.println(user2);
如果你想通過反射範例化一個類的物件,可以使用BeanUtils的instantiateClass
方法。例如:
User user = BeanUtils.instantiateClass(User.class);
System.out.println(user);
如果你想獲取某個類的指定方法,可以使用BeanUtils的findDeclaredMethod
方法。例如:
Method declaredMethod = BeanUtils.findDeclaredMethod(User.class, "getId");
System.out.println(declaredMethod.getName());
如果你想獲取某個方法的引數,可以使用BeanUtils的findPropertyForMethod
方法。例如:
Method declaredMethod = BeanUtils.findDeclaredMethod(User.class, "getId");
PropertyDescriptor propertyForMethod = BeanUtils.findPropertyForMethod(declaredMethod);
System.out.println(propertyForMethod.getName());
如果你對BeanUtils比較感興趣,可以看看下面內容:
有時候,我們需要在專案中使用反射
功能,如果使用最原始的方法來開發,程式碼量會非常多,而且很麻煩,它需要處理一大堆異常以及存取許可權等問題。
好訊息是spring給我們提供了一個ReflectionUtils
工具,它在org.springframework.util
包下面。
如果你想獲取某個類的某個方法,可以使用ReflectionUtils類的findMethod
方法。例如:
Method method = ReflectionUtils.findMethod(User.class, "getId");
如果你想獲取某個類的某個欄位,可以使用ReflectionUtils類的findField
方法。例如:
Field field = ReflectionUtils.findField(User.class, "id");
如果你想通過反射呼叫某個方法,傳遞引數,可以使用ReflectionUtils類的invokeMethod
方法。例如:
ReflectionUtils.invokeMethod(method, springContextsUtil.getBean(beanName), param);
如果你想判斷某個欄位是否常數,可以使用ReflectionUtils類的isPublicStaticFinal
方法。例如:
Field field = ReflectionUtils.findField(User.class, "id");
System.out.println(ReflectionUtils.isPublicStaticFinal(field));
如果你想判斷某個方法是否equals方法,可以使用ReflectionUtils類的isEqualsMethod
方法。例如:
Method method = ReflectionUtils.findMethod(User.class, "getId");
System.out.println(ReflectionUtils.isEqualsMethod(method));
當然這個類還有不少有趣的方法,感興趣的朋友,可以看看下面內容:
有時候,為了安全考慮,需要將引數只用base64
編碼。
這時就能直接使用org.springframework.util
包下的Base64Utils
工具類。
它裡面包含:encode
和decode
方法,用於對資料進行加密和解密。例如:
String str = "abc";
String encode = new String(Base64Utils.encode(str.getBytes()));
System.out.println("加密後:" + encode);
try {
String decode = new String(Base64Utils.decode(encode.getBytes()), "utf8");
System.out.println("解密後:" + decode);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
執行結果:
加密後:YWJj
解密後:abc
我們在做字元轉換的時候,經常需要指定字元編碼,比如:UTF-8、ISO-8859-1等等。
這時就可以直接使用java.nio.charset
包下的StandardCharsets
類中靜態變數。
例如:
String str = "abc";
String encode = new String(Base64Utils.encode(str.getBytes()));
System.out.println("加密後:" + encode);
String decode = new String(Base64Utils.decode(encode.getBytes())
, StandardCharsets.UTF_8);
System.out.println("解密後:" + decode);
有時候,我們需要對資料進行加密處理,比如:md5或sha256。
可以使用apache的org.apache.commons.codec.digest
包下的DigestUtils
類。
如果你想對資料進行md5加密,可以使用DigestUtils的md5Hex
方法。例如:
String md5Hex = DigestUtils.md5Hex("蘇三說技術");
System.out.println(md5Hex);
如果你想對資料進行sha256加密,可以使用DigestUtils的sha256Hex
方法。例如:
String md5Hex = DigestUtils.sha256Hex("蘇三說技術");
System.out.println(md5Hex);
當然這個工具還有很多其他的加密方法:
有時候,我們需要把資料進行序列化
和反序列化
處理。
傳統的做法是某個類實現Serializable
介面,然後重新它的writeObject
和readObject
方法。
但如果使用org.springframework.util
包下的SerializationUtils
工具類,能更輕鬆實現序列化和反序列化功能。例如:
Map<String, String> map = Maps.newHashMap();
map.put("a", "1");
map.put("b", "2");
map.put("c", "3");
byte[] serialize = SerializationUtils.serialize(map);
Object deserialize = SerializationUtils.deserialize(serialize);
System.out.println(deserialize);
很多時候,我們會在程式碼中定義http的返回碼,比如:介面正常返回200,異常返回500,介面找不到返回404,介面不可用返回502等。
private int SUCCESS_CODE = 200;
private int ERROR_CODE = 500;
private int NOT_FOUND_CODE = 404;
其實org.springframework.http
包下的HttpStatus列舉,或者org.apache.http
包下的HttpStatus
介面,已經把常用的http返回碼給我們定義好了,直接拿來用就可以了,真的不用再重複定義了。
好了,今天的內容分享到這裡。
工作當中還有很多好用的小工具,歡迎在下方留言。
如果覺得這篇文章對你有些幫助的話,麻煩給我點個贊喔,謝謝你的支援。