首页  >  文章  >  后端开发  >  鉴于数据在 Golang 中使用 128 位密钥加密,如何在 Java 和 Scala 中解密 AES 加密数据?

鉴于数据在 Golang 中使用 128 位密钥加密,如何在 Java 和 Scala 中解密 AES 加密数据?

Linda Hamilton
Linda Hamilton原创
2024-10-27 04:05:29517浏览

How can I decrypt AES-encrypted data in Java and Scala, given that the data was encrypted in Golang with a 128-bit key?

Golang 中的 AES 加密和 Java 中的解密

提供的 Golang 代码使用 128 位密钥的 AES 算法对数据进行加密。为了解密这些数据,我们可以使用类似的 Java 解码器来确保两种语言之间的兼容性。

Java 解码器

<code class="java">String decode(String base64Text, byte[] key) throws InvalidAlgorithmParameterException,NoSuchAlgorithmException, InvalidKeyException, BadPaddingException, IllegalBlockSizeException {
    byte[] inputArr = Base64.getUrlDecoder().decode(base64Text);
    SecretKeySpec skSpec = new SecretKeySpec(key, "AES");
    Cipher cipher = Cipher.getInstance("AES/CFB/NoPadding");
    int blockSize = cipher.getBlockSize();
    IvParameterSpec iv = new IvParameterSpec(Arrays.copyOf(inputArr, blockSize));
    byte[] dataToDecrypt = Arrays.copyOfRange(inputArr, blockSize, inputArr.length);
    cipher.init(Cipher.DECRYPT_MODE, skSpec, iv);
    byte[] result = cipher.doFinal(dataToDecrypt);
    return new String(result, StandardCharsets.UTF_8);
}</code>

Scala 解码器

<code class="scala">def decode(input:String, key:String) = {
    val cipher = Cipher.getInstance("AES/CFB/NoPadding")
    val blockSize = cipher.getBlockSize()
    val keyBytes = key.getBytes()
    val inputArr = Base64.getUrlDecoder().decode(input)
    val skSpec = new SecretKeySpec(keyBytes, "AES")
    val iv = new IvParameterSpec(inputArr.slice(0, blockSize).toArray)
    val dataToDecrypt = inputArr.slice(blockSize, inputArr.size)
    cipher.init(Cipher.DECRYPT_MODE, skSpec, iv)
    new String(cipher.doFinal(dataToDecrypt.toArray))
}</code>

用法

要解密加密文本,请使用提供的 Java 或 Scala 解码器。例如,如果加密文本为“c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0=”,密钥为“0123456789abcdef”,则解密文本将为“test text 123”。

以上是鉴于数据在 Golang 中使用 128 位密钥加密,如何在 Java 和 Scala 中解密 AES 加密数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn