>백엔드 개발 >Golang >데이터가 128비트 키를 사용하여 Golang에서 암호화된 경우 Java 및 Scala에서 AES로 암호화된 데이터를 어떻게 해독할 수 있습니까?

데이터가 128비트 키를 사용하여 Golang에서 암호화된 경우 Java 및 Scala에서 AES로 암호화된 데이터를 어떻게 해독할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-27 04:05:29659검색

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

Golang의 AES 암호화 및 Java의 암호 해독

제공되는 Golang 코드는 128비트 키와 AES 알고리즘을 사용하여 데이터를 암호화합니다. 이 데이터를 해독하려면 유사한 Java 디코더를 사용하여 두 언어 간의 호환성을 보장할 수 있습니다.

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>

사용 방법

암호화된 텍스트를 복호화하려면 제공된 Java 또는 Scala 디코더를 사용하세요. 예를 들어 암호화된 텍스트가 "c1bpFhxn74yzHQs-vgLcW6E5yL8zJfgceEQgYl0="이고 키가 "0123456789abcdef"인 경우 해독된 텍스트는 "테스트 텍스트 123"이 됩니다.

위 내용은 데이터가 128비트 키를 사용하여 Golang에서 암호화된 경우 Java 및 Scala에서 AES로 암호화된 데이터를 어떻게 해독할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.