> 백엔드 개발 > Golang > Java 및 Scala를 사용하여 Golang에서 생성된 AES 암호화된 텍스트를 해독하는 방법은 무엇입니까?

Java 및 Scala를 사용하여 Golang에서 생성된 AES 암호화된 텍스트를 해독하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-10-29 20:02:02
원래의
831명이 탐색했습니다.

How to decrypt AES encrypted text generated in Golang using Java and Scala?

Golang의 AES 암호화 및 Java의 복호화

Java의 AES 암호화 텍스트 복호화

Golang 함수로 생성된 AES 암호화된 텍스트를 해독하려면 Java 구현이 필요합니다. 아래 Java 코드는 복호화 프로세스를 보여줍니다.

<code class="java">public class AESDecryption {

    public static String decode(String base64Text, byte[] key) throws Exception {
        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);
    }

    public static void main(String[] args) {
        try {
            String encryptedText = "c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0=";
            byte[] key = "0123456789abcdef".getBytes();
            String decryptedText = decode(encryptedText, key);
            System.out.println("Decrypted text: " + decryptedText);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}</code>
로그인 후 복사

이 Java 코드는 Golang 함수에 의해 생성된 암호화된 텍스트를 성공적으로 복호화하고 원래 일반 텍스트를 반환해야 합니다.

Scala 버전

Scala 버전의 암호 해독 코드는 다음과 같습니다.

<code class="scala">object AESDecryption {

    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))
    }

    def main(args: Array[String]): Unit = {
        val encryptedText = "c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0="
        val key = "0123456789abcdef"
        val decryptedText = decode(encryptedText, key)
        println("Decrypted text: " + decryptedText)
    }
}</code>
로그인 후 복사

이 Scala 코드는 AES 암호화된 텍스트도 해독하고 일반 텍스트를 인쇄합니다.

위 내용은 Java 및 Scala를 사용하여 Golang에서 생성된 AES 암호화된 텍스트를 해독하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿