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 メソッドを使用した別のアプローチでは、「計算された認証トークンが入力認証トークンと一致しません」というエラーが生成されます。
リーリー
ただし、実際の暗号化テキスト認証トークンを含む配列は、暗号化テキストのみを含むものとして引き続き処理されます。修正するには、これも抽出します:リーリー
以上がAES-GSM 方式を使用して GO でエンコードされた C# 文字列を復号化するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。