ホームページ >バックエンド開発 >Golang >AES-GSM 方式を使用して GO でエンコードされた C# 文字列を復号化する

AES-GSM 方式を使用して GO でエンコードされた C# 文字列を復号化する

PHPz
PHPz転載
2024-02-10 09:39:091207ブラウズ

使用 AES-GSM 方法解密在 GO 中编码的 C# 字符串

php エディタ Xigua は、GO 言語 AES-GSM で C# 文字列を復号する方法を紹介します。 AES-GSM は、AES (Advanced Encryption Standard) と GSM (Global System for Mobile Communications) の利点を組み合わせた高度な暗号化規格です。 AES-GSM 方式を使用すると、GO でエンコードされた C# 文字列を効果的に復号化でき、データの安全な送信と保護が可能になります。この記事では、読者がこの暗号化および復号化テクノロジを簡単に習得できるように、AES-GSM の原理と使用手順を詳しく紹介します。

質問内容

goでaes-gcmで暗号化された文字列とそのパスフレーズがあり、それをc#で復号しようとしています。ただし、C# で復号化する正しい方法が見つかりません。 発生するエラーには、iv のサイズ、ブロックの長さが C# 復号化アルゴリズムに適していないことが記載されています。 go の値は次のとおりです:

リーリー リーリー リーリー

コードに進む: https://go.dev/play/p/jn8ie61ntzw

これは go の復号化コードです

リーリー

これは go の暗号化コードです

リーリー

同じ復号化されたログインを C# で複製しようとしています。これにより、最終的な文字列を復号化して生成できるようになります。

C# でいくつかの復号化ロジックを試しました。それらはここにあります:

  • https://dotnetfiddle.net/32sb5m この関数は system.security.cryptography 名前空間を使用しますが、iv サイズが間違った結果になります。

  • https://dotnetfiddle.net/wxkuyr .net 5 用に上記を修正したバージョンでも同じ結果が得られます

  • https://dotnetfiddle.net/6iftps bouncy Castle ライブラリを使用すると「mac check in gcm failed」エラーが発生する

  • https://dotnetfiddle.net/8mjs3g rfc2898derivebytes メソッドを使用した別のアプローチでは、「計算された認証トークンが入力認証トークンと一致しません」というエラーが生成されます。

現在使用されている方法は正しいですか、それとも C# で aes-gcm を復号化する別の方法はありますか? C# に関してこれらのエラーを回避するにはどうすればよいでしょうか?

解決策

最後のコードに近づいています。 go 生成された暗号文の末尾に認証タグを追加します。ここで正しく抽出されました:

リーリー

ただし、実際の暗号化テキスト認証トークンを含む配列は、暗号化テキストのみを含むものとして引き続き処理されます。修正するには、これも抽出します:

リーリー

以上がAES-GSM 方式を使用して GO でエンコードされた C# 文字列を復号化するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はstackoverflow.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。