Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Bagaimanakah saya boleh menyahsulit data yang disulitkan AES dalam Java dan Scala, memandangkan data itu disulitkan di Golang dengan kunci 128-bit?

Bagaimanakah saya boleh menyahsulit data yang disulitkan AES dalam Java dan Scala, memandangkan data itu disulitkan di Golang dengan kunci 128-bit?

Linda Hamilton
Linda Hamiltonasal
2024-10-27 04:05:29525semak imbas

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

Penyulitan AES dalam Golang dan Penyahsulitan dalam Java

Kod Golang yang disediakan menyulitkan data menggunakan algoritma AES dengan kunci 128-bit. Untuk menyahsulit data ini, kami boleh menggunakan penyahkod Java yang serupa untuk memastikan keserasian antara kedua-dua bahasa.

Penyahkod 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>

Penyahkod 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>

Penggunaan

Untuk menyahsulit teks yang disulitkan, gunakan penyahkod Java atau Scala yang disediakan. Sebagai contoh, jika teks yang disulitkan ialah "c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0=" dan kuncinya ialah "0123456789abcdef", teks yang dinyahsulitkan ialah "teks ujian 123".

Atas ialah kandungan terperinci Bagaimanakah saya boleh menyahsulit data yang disulitkan AES dalam Java dan Scala, memandangkan data itu disulitkan di Golang dengan kunci 128-bit?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn