gpt4 book ai didi

java - Angular 4 中的 AES 128 加密和 Java 中的解密

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:47:19 24 4
gpt4 key购买 nike

我使用以下代码在 Angular 4 中使用 CryptoJS(AES) 进行加密:

const key = CryptoJS.enc.Utf8.parse('7061737323313233');
const iv = CryptoJS.enc.Utf8.parse('7061737323313233');
const encrypted = CryptoJS.AES.encrypt('String to encrypt', key, {
keySize: 16,
iv: iv,
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
console.log('Encrypted :' + encrypted);

和下面使用 AES 解密的 java 代码:

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class Encryption {

private static SecretKeySpec secretKey;
private static byte[] key;

public static void setKey(String myKey)
{
MessageDigest sha = null;
try {
key = myKey.getBytes("UTF-8");
sha = MessageDigest.getInstance("SHA-1");
key = sha.digest(key);
key = Arrays.copyOf(key, 16);
secretKey = new SecretKeySpec(key, "AES");
}
catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}

public static String encrypt(String strToEncrypt, String secret)
{
try
{
setKey(secret);
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING");
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
return Base64.getEncoder().encodeToString(cipher.doFinal(strToEncrypt.getBytes("UTF-8")));
}
catch (Exception e)
{
System.out.println("Error while encrypting: " + e.toString());
}
return null;
}

public static String decrypt(String strToDecrypt, String secret)
{
try
{
setKey(secret);
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING");
cipher.init(Cipher.DECRYPT_MODE, secretKey);
return new String(cipher.doFinal(Base64.getDecoder().decode(strToDecrypt)));
}
catch (Exception e)
{
System.out.println("Error while decrypting: " + e.toString());
}
return null;
}
}

public class Test {
public static void main(String[] args) {
final String secretKey = "7061737323313233";
String originalString = "Response from angular";
String decryptedString = Encryption.decrypt(originalString, secretKey);
System.out.println(decryptedString);
}
}

如果我独立运行 Angular 和 java 代码进行加密和解密,它们都可以正常工作。但是当我使用 angular 加密并使用 java 解密时,它给出了错误:

Error while decrypting: javax.crypto.BadPaddingException: Given final block not properly padded

现在我的问题是 angular 和 java 中的填充存在差异。在 angular 中它是 Pkcs7,在 java 中它是 Pkcs5 但这个链接 Padding然后说两者相同,为什么会出现此错误。请帮助我

最佳答案

我生成 key 的代码在 Java 中生成了错误的 key 。所以我将其更改为:

 Key key = new SecretKeySpec(key.getBytes("UTF-8"),"AES" );

现在一切正常

关于java - Angular 4 中的 AES 128 加密和 Java 中的解密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50679221/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com