Rumah > pembangunan bahagian belakang > Golang > 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
Lepaskan: 2024-10-27 04:05:29
asal
636 orang telah melayarinya

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan