From a55a0be539a660f5d2b405ccb8ac2cee7cfbc065 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=AB=98=E9=BE=99?= Date: Mon, 8 Aug 2022 19:47:32 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8DSecureUtil=E7=B1=BB=E4=B8=ADH?= =?UTF-8?q?MAC=E7=AE=97=E6=B3=95=E5=8A=A0=E5=AF=86=E5=99=A8=E5=88=9B?= =?UTF-8?q?=E5=BB=BA=E6=96=B9=E6=B3=95=E4=BC=A0=E5=85=A5=E7=9A=84key?= =?UTF-8?q?=E5=8F=82=E6=95=B0=E4=B8=BA=E7=A9=BA=E6=97=B6=E6=8A=9B=E5=BC=82?= =?UTF-8?q?=E5=B8=B8=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/cn/hutool/crypto/SecureUtil.java | 25 ++++++++++++++++--- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/hutool-crypto/src/main/java/cn/hutool/crypto/SecureUtil.java b/hutool-crypto/src/main/java/cn/hutool/crypto/SecureUtil.java index 575cbb377..40b07fb87 100755 --- a/hutool-crypto/src/main/java/cn/hutool/crypto/SecureUtil.java +++ b/hutool-crypto/src/main/java/cn/hutool/crypto/SecureUtil.java @@ -3,7 +3,9 @@ package cn.hutool.crypto; import cn.hutool.core.codec.Base64; import cn.hutool.core.io.FileUtil; import cn.hutool.core.lang.Validator; +import cn.hutool.core.util.ArrayUtil; import cn.hutool.core.util.HexUtil; +import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.crypto.asymmetric.AsymmetricAlgorithm; import cn.hutool.crypto.asymmetric.RSA; @@ -633,7 +635,7 @@ public class SecureUtil { * @since 3.3.0 */ public static HMac hmac(HmacAlgorithm algorithm, String key) { - return new HMac(algorithm, StrUtil.utf8Bytes(key)); + return hmac(algorithm, StrUtil.isNotEmpty(key)? StrUtil.utf8Bytes(key): null); } /** @@ -645,6 +647,9 @@ public class SecureUtil { * @since 3.0.3 */ public static HMac hmac(HmacAlgorithm algorithm, byte[] key) { + if (ArrayUtil.isEmpty(key)) { + key = generateKey(algorithm.getValue()).getEncoded(); + } return new HMac(algorithm, key); } @@ -657,6 +662,9 @@ public class SecureUtil { * @since 3.0.3 */ public static HMac hmac(HmacAlgorithm algorithm, SecretKey key) { + if (ObjectUtil.isNull(key)) { + key = generateKey(algorithm.getValue()); + } return new HMac(algorithm, key); } @@ -671,7 +679,7 @@ public class SecureUtil { * @since 3.3.0 */ public static HMac hmacMd5(String key) { - return hmacMd5(StrUtil.utf8Bytes(key)); + return hmacMd5(StrUtil.isNotEmpty(key)? StrUtil.utf8Bytes(key): null); } /** @@ -684,6 +692,9 @@ public class SecureUtil { * @return {@link HMac} */ public static HMac hmacMd5(byte[] key) { + if (ArrayUtil.isEmpty(key)) { + key = generateKey(HmacAlgorithm.HmacMD5.getValue()).getEncoded(); + } return new HMac(HmacAlgorithm.HmacMD5, key); } @@ -710,7 +721,7 @@ public class SecureUtil { * @since 3.3.0 */ public static HMac hmacSha1(String key) { - return hmacSha1(StrUtil.utf8Bytes(key)); + return hmacSha1(StrUtil.isNotEmpty(key)? StrUtil.utf8Bytes(key): null); } /** @@ -723,6 +734,9 @@ public class SecureUtil { * @return {@link HMac} */ public static HMac hmacSha1(byte[] key) { + if (ArrayUtil.isEmpty(key)) { + key = generateKey(HmacAlgorithm.HmacMD5.getValue()).getEncoded(); + } return new HMac(HmacAlgorithm.HmacSHA1, key); } @@ -749,7 +763,7 @@ public class SecureUtil { * @since 5.6.0 */ public static HMac hmacSha256(String key) { - return hmacSha256(StrUtil.utf8Bytes(key)); + return hmacSha256(StrUtil.isNotEmpty(key)? StrUtil.utf8Bytes(key): null); } /** @@ -763,6 +777,9 @@ public class SecureUtil { * @since 5.6.0 */ public static HMac hmacSha256(byte[] key) { + if (ArrayUtil.isEmpty(key)) { + key = generateKey(HmacAlgorithm.HmacMD5.getValue()).getEncoded(); + } return new HMac(HmacAlgorithm.HmacSHA256, key); }