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中文網其他相關文章!