Heim >Backend-Entwicklung >Golang >Wie kann ich AES-verschlüsselte Daten in Java und Scala entschlüsseln, vorausgesetzt, die Daten wurden in Golang mit einem 128-Bit-Schlüssel verschlüsselt?
AES-Verschlüsselung in Golang und Entschlüsselung in Java
Der bereitgestellte Golang-Code verschlüsselt Daten mithilfe des AES-Algorithmus mit einem 128-Bit-Schlüssel. Um diese Daten zu entschlüsseln, können wir einen ähnlichen Java-Decoder verwenden, um die Kompatibilität zwischen den beiden Sprachen sicherzustellen.
Java-Decoder
<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-Decoder
<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>
Verwendung
Um den verschlüsselten Text zu entschlüsseln, verwenden Sie den mitgelieferten Java- oder Scala-Decoder. Wenn der verschlüsselte Text beispielsweise „c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0=" lautet und der Schlüssel „0123456789abcdef" lautet, wäre der entschlüsselte Text „Testtext 123“.
Das obige ist der detaillierte Inhalt vonWie kann ich AES-verschlüsselte Daten in Java und Scala entschlüsseln, vorausgesetzt, die Daten wurden in Golang mit einem 128-Bit-Schlüssel verschlüsselt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!