Question :
J'ai réussi à chiffrer du texte en utilisant AES dans Go. Cependant, je suis confronté à des difficultés pour déchiffrer le texte crypté en Java. Pouvez-vous nous aider à comprendre le flux de décryptage Java et un décodeur Java fonctionnel ?
Réponse :
Décodeur Java :
<code class="java">import java.nio.charset.StandardCharsets; import java.security.InvalidAlgorithmParameterException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.util.Arrays; import java.util.Base64; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.IvParameterSpec; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKeySpec; public class AesDecrypter { public static String decode(String base64Text, byte[] key) throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidAlgorithmParameterException, 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>
Décodeur Scala :
<code class="scala">import java.nio.charset.StandardCharsets import javax.crypto._ import java.security.spec.IvParameterSpec import java.security.spec.SecretKeySpec import java.util.Base64 object AesDecrypter { def decode(input:String, key:String): 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>
Démo :
À des fins de démonstration, encodons la chaîne "test text 123" avec la fonction de chiffrement écrite en Go et décodez-la avec la fonction de décryptage écrite en Java (ou Scala) :
// Go encoder key := []byte("0123456789abcdef") text := "test text 123" encryptedText := encrypt(key, text) println(encryptedText) // prints c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0= // Java decoder byte[] keyBytes = "0123456789abcdef".getBytes(); String decodedText = AesDecrypter.decode(encryptedText, keyBytes); System.out.println(decodedText); // prints test text 123 // Scala decoder val decodedText = AesDecrypter.decode(encryptedText, "0123456789abcdef") println(decodedText) // prints test text 123
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!