node.js、PythonおよびGo AES-128-ECBの復号化結果の違いと理由の分析
このペーパーでは、node.js、python、goの3つのプログラミング言語を使用して、AES-128-ECB復号化アルゴリズムを実装する際に出力結果に違いがある理由を分析します。 3つの言語のコード目標は一貫しています - 同じ暗号化されたデータを復号化しますが、node.jsの復号化の結果はPythonの結果と一致しません。 PythonとGo ga sustに復号化されますが、node.jsの復号化は失敗します。これは主に、コードの実装の詳細とデータ処理方法の違いに起因します。
問題のコアは、node.jsコードの復号化結果のエラーにあります。 Pythonはcryptography
ライブラリを使用し、GOは内蔵のcrypto/aes
パッケージを使用し、node.jsはcrypto.createDecipheriv
関数を使用します(注:元のテキストで言及されたcreatechipheriv
タイプミスであり、 createDecipheriv
になります)。
node.jsコードでは、重要なエラーはデータ処理にあります。
const x = ibuf.slice(8);
このコードは、8番目のバイトから始まるibuf
バッファーからのデータのみをインターセプトします。ただし、正しいアプローチは、 totalsize
変数(暗号化されたデータサイズを表す)に基づいて復号化する必要があるデータの長さを決定することです。 ibuf
バッファには追加のヘッダー情報が含まれている可能性があるため、8番目のバイトから始めるのではなく、復号化のtotalsize
に従って正しいデータを傍受する必要があります。これにより、node.jsコードがデータの一部のみを復号化するため、エラー結果が得られます。
さらに、元のテキストは、 createDecipheriv
関数自体が正しく使用されており、以前のcreatechipheriv
エラーが間違っていることを明確に述べています。提供された補足サンプルコードは、 crypto.createDecipheriv
とcrypto.createCipheriv
の正しい使用法と、node.js環境とBuffer
オブジェクトの正しい動作方法を検証します。この例コードでは、暗号化と復号化の両方が適切に機能し、node.jsのcrypto
ライブラリ自体が問題ないことを証明しています。
したがって、問題のルートは、アルゴリズム自体またはライブラリのエラーではなく、node.jsコードによるデータのエラー処理にあります。 node.jsコードがデータを正しく処理し、正しい関数を使用できる場合、その復号化の結果はPythonの結果と一致します。
以上がnode.js、python、およびgoの復号化結果の違い:node.jsがAES-128-ECBを復号化できないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

Pythonは、データサイエンス、Web開発、自動化タスクに適していますが、Cはシステムプログラミング、ゲーム開発、組み込みシステムに適しています。 Pythonは、そのシンプルさと強力なエコシステムで知られていますが、Cは高性能および基礎となる制御機能で知られています。

2時間以内にPythonの基本的なプログラミングの概念とスキルを学ぶことができます。 1.変数とデータ型、2。マスターコントロールフロー(条件付きステートメントとループ)、3。機能の定義と使用を理解する4。

Pythonは、Web開発、データサイエンス、機械学習、自動化、スクリプトの分野で広く使用されています。 1)Web開発では、DjangoおよびFlask Frameworksが開発プロセスを簡素化します。 2)データサイエンスと機械学習の分野では、Numpy、Pandas、Scikit-Learn、Tensorflowライブラリが強力なサポートを提供します。 3)自動化とスクリプトの観点から、Pythonは自動テストやシステム管理などのタスクに適しています。

2時間以内にPythonの基本を学ぶことができます。 1。変数とデータ型を学習します。2。ステートメントやループの場合などのマスター制御構造、3。関数の定義と使用を理解します。これらは、簡単なPythonプログラムの作成を開始するのに役立ちます。

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

WebStorm Mac版
便利なJavaScript開発ツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール
