This commit is contained in:
Looly
2023-12-29 20:55:55 +08:00
parent 91178e45a8
commit 6facfcfc4d
101 changed files with 271 additions and 307 deletions

View File

@@ -12,9 +12,7 @@
package org.dromara.hutool.crypto;
import org.dromara.hutool.core.exception.ExceptionUtil;
import org.dromara.hutool.core.exception.HutoolException;
import org.dromara.hutool.core.text.StrUtil;
/**
* 加密异常

View File

@@ -28,12 +28,12 @@ import java.time.Instant;
* <p>参考https://github.com/jchambers/java-otp</p>
* OTP基于具有时间戳计数器的OTP。
* 通过定义纪元T0的开始并以时间间隔TI为单位计数将当前时间戳变为整数时间计数器TC。 例如:
*
* <p>
* TC = floor,
* TOTP = HOTPSecretKeyTC
* TOTP-Value = TOTP mod 10d其中d是一次性密码的所需位数。
* 像google auth的二步认证使用了这种方式。
*
* <p>
* 认证过程
* 生成二维码,带有otpauth链接的google地址
* 生成公用密钥
@@ -42,8 +42,7 @@ import java.time.Instant;
* app每30秒生成一个6位校验码,用户使用这个码来网站进行登陆
* 服务器使用存储的密钥+fmac算法生成6位随机数,与客户端传来的数进行对比
* 两个码相等,授权成功,反之,失败.注意服务端可以根据当前登陆的用户名拿到它的密钥有了密钥再进行totp的算法生成校验码
*
*
* <p>
* 登陆的过程整理
* 用户和密码先登陆
* session里存储了用户名等信息
@@ -53,7 +52,6 @@ import java.time.Instant;
* 提交到服务端服务端根据用户名取出对应的密钥然后使用totp算法生成6位数字
* 如果服务端与客户端数字相同,表示登陆成功!
*
*
* @author Looly
*/
public class TOTP extends HOTP {

View File

@@ -14,7 +14,6 @@ package org.dromara.hutool.crypto.symmetric;
import org.dromara.hutool.core.codec.binary.Base64;
import org.dromara.hutool.core.codec.HexUtil;
import org.dromara.hutool.core.lang.Console;
import org.dromara.hutool.core.util.RandomUtil;
import org.dromara.hutool.crypto.KeyUtil;
import org.dromara.hutool.crypto.Mode;

View File

@@ -24,7 +24,7 @@ public class ChaCha20Test {
@Test
public void encryptAndDecryptTest() {
// 32 for 256 bit key or 16 for 128 bit
// 32 for 256-bit key or 16 for 128 bit
final byte[] key = RandomUtil.randomBytes(32);
// 64 bit IV required by ChaCha20
final byte[] iv = RandomUtil.randomBytes(12);

View File

@@ -12,7 +12,6 @@
package org.dromara.hutool.crypto.symmetric;
import org.dromara.hutool.core.lang.Console;
import org.dromara.hutool.core.text.StrUtil;
import org.dromara.hutool.core.util.ByteUtil;
import org.dromara.hutool.crypto.KeyUtil;

View File

@@ -13,7 +13,6 @@
package org.dromara.hutool.crypto.symmetric;
import org.dromara.hutool.core.util.CharsetUtil;
import org.dromara.hutool.crypto.provider.GlobalProviderFactory;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;