ホームページ > バックエンド開発 > Golang > データが Golang で 128 ビット キーを使用して暗号化されている場合、AES で暗号化されたデータを Java および Scala で復号するにはどうすればよいですか?

データが Golang で 128 ビット キーを使用して暗号化されている場合、AES で暗号化されたデータを Java および Scala で復号するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-10-27 04:05:29
オリジナル
657 人が閲覧しました

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 デコーダを使用して 2 つの言語間の互換性を確保できます。

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」になります。

以上がデータが Golang で 128 ビット キーを使用して暗号化されている場合、AES で暗号化されたデータを Java および Scala で復号するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート