mirror of
https://gitee.com/chinabugotech/hutool.git
synced 2025-07-21 15:09:48 +08:00
fix code
This commit is contained in:
@@ -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;
|
||||
|
@@ -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());
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user