This commit is contained in:
Looly
2023-04-26 13:49:23 +08:00
parent 13d0ce8817
commit c2d419ffdc
10 changed files with 182 additions and 329 deletions

View File

@@ -2,6 +2,7 @@ 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

@@ -1,38 +1,41 @@
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;
import java.nio.charset.StandardCharsets;
public class RC4Test {
@Test
public void testCryptMessage() {
final String key = "This is pretty long key";
final RC4 rc4 = new RC4(key);
final byte[] key = "This is pretty long key".getBytes();
final SymmetricCrypto SymmetricCrypto = new SymmetricCrypto("RC4", key);
final String message = "Hello, World!";
final byte[] crypt = rc4.encrypt(message);
final String msg = rc4.decrypt(crypt);
final byte[] crypt = SymmetricCrypto.encrypt(message);
final String msg = SymmetricCrypto.decryptStr(crypt);
Assertions.assertEquals(message, msg);
final String message2 = "Hello, World this is megssage 2";
final byte[] crypt2 = rc4.encrypt(message2);
final String msg2 = rc4.decrypt(crypt2);
final byte[] crypt2 = SymmetricCrypto.encrypt(message2);
final String msg2 = SymmetricCrypto.decryptStr(crypt2);
Assertions.assertEquals(message2, msg2);
}
@Test
public void testCryptWithChineseCharacters() {
final String message = "这是一个中文消息!";
final String key = "我是一个文件密钥";
final RC4 rc4 = new RC4(key);
final byte[] crypt = rc4.encrypt(message);
final String msg = rc4.decrypt(crypt);
final byte[] key = "我是一个文件密钥".getBytes(StandardCharsets.UTF_8);
final SymmetricCrypto SymmetricCrypto = new SymmetricCrypto("RC4", key);
final byte[] crypt = SymmetricCrypto.encrypt(message);
final String msg = SymmetricCrypto.decryptStr(crypt);
Assertions.assertEquals(message, msg);
final String message2 = "这是第二个中文消息!";
final byte[] crypt2 = rc4.encrypt(message2);
final String msg2 = rc4.decrypt(crypt2);
final byte[] crypt2 = SymmetricCrypto.encrypt(message2);
final String msg2 = SymmetricCrypto.decryptStr(crypt2);
Assertions.assertEquals(message2, msg2);
}
@@ -40,14 +43,14 @@ public class RC4Test {
public void testDecryptWithHexMessage() {
final String message = "这是第一个用来测试密文为十六进制字符串的消息!";
final String key = "生成一个密钥";
final RC4 rc4 = new RC4(key);
final String encryptHex = rc4.encryptHex(message, CharsetUtil.UTF_8);
final String msg = rc4.decrypt(encryptHex);
final SymmetricCrypto SymmetricCrypto = new SymmetricCrypto("RC4", key.getBytes(StandardCharsets.UTF_8));
final String encryptHex = SymmetricCrypto.encryptHex(message, CharsetUtil.UTF_8);
final String msg = SymmetricCrypto.decryptStr(encryptHex);
Assertions.assertEquals(message, msg);
final String message2 = "这是第二个用来测试密文为十六进制字符串的消息!";
final String encryptHex2 = rc4.encryptHex(message2);
final String msg2 = rc4.decrypt(encryptHex2);
final String encryptHex2 = SymmetricCrypto.encryptHex(message2);
final String msg2 = SymmetricCrypto.decryptStr(encryptHex2);
Assertions.assertEquals(message2, msg2);
}
@@ -56,14 +59,21 @@ public class RC4Test {
public void testDecryptWithBase64Message() {
final String message = "这是第一个用来测试密文为Base64编码的消息";
final String key = "生成一个密钥";
final RC4 rc4 = new RC4(key);
final String encryptHex = rc4.encryptBase64(message, CharsetUtil.UTF_8);
final String msg = rc4.decrypt(encryptHex);
final SymmetricCrypto SymmetricCrypto = new SymmetricCrypto("RC4", key.getBytes(StandardCharsets.UTF_8));
final String encryptHex = SymmetricCrypto.encryptBase64(message, CharsetUtil.UTF_8);
final String msg = SymmetricCrypto.decryptStr(encryptHex);
Assertions.assertEquals(message, msg);
final String message2 = "这是第一个用来测试密文为Base64编码的消息";
final String encryptHex2 = rc4.encryptBase64(message2);
final String msg2 = rc4.decrypt(encryptHex2);
final String encryptHex2 = SymmetricCrypto.encryptBase64(message2);
final String msg2 = SymmetricCrypto.decryptStr(encryptHex2);
Assertions.assertEquals(message2, msg2);
}
@Test
void decryptTest() {
GlobalProviderFactory.setUseCustomProvider(false);
final String key16 = "1234567890123456";
final SymmetricCrypto aes = new SymmetricCrypto("SymmetricCrypto", key16.getBytes());
}
}