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

PHPz
リリース: 2024-02-10 09:39:09
転載
1114 人が閲覧しました

使用 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 までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!