ホームページ >バックエンド開発 >PHPチュートリアル >暗号化アルゴリズムは、各言語で異なる原則とソリューションを設計しています。
Atitit.暗号化アルゴリズムの設計 言語ごとに異なる原理とソリューション java php c#
Atitit.暗号化アルゴリズム des aes 異なる言語原則と解決策 java php c#
1。暗号化アルゴリズムのパラメータ:: アルゴリズム/モード/パディング 1
2。標準暗号化API使用プロセス 1
2.1 MD5—— 16 ビット 長さが 128 (または他の指定された長さ) になるように キー をパディングします2
2.2. は key2 を生成します
2.3. 操作2
3。Aes暗号化原理アーキテクチャ図 2
4 。 キー が矛盾しています4 5。暗号化モード4 5.1. Ecb 4 5.2. 3.2 CBC モード:5 5.3. OFBモード: 6 5.4. 3.3 CFBモード: 7 6パディングメソッド。 8 6.1.1. パディングメソッド アーキテクチャ図9 7。アルゴリズム/モード/パディング 比較表9 8.16暗号化後の長さバイト109Java の暗号化シリーズ。 119 .1. セキュリティ プロバイダー アーキテクチャ 119 1.1. エンジンとアルゴリズム。エンジンは、暗号化、復号化などの操作として理解できます。 >9.2. 3.2.12 SecureRandom クラス12 9 .3. 🎜> キーインターフェース12 9 3.4.3 SecretKeySpecクラス141 AesFAQ アルゴリズム ソリューション 14 11. 参照15 /* モデル化されたキーの概念。キーは異なるエンティティ間で送信される必要があるため、すべてのキーはシリアル化可能である必要があります*/ 文字エンコード方式、特に中国語をキーとして使用する場合。 key =MD5.getMD5_16bit(キー,"utf-8" ); バイト[] バイト = key.getBytes (); SecretKeySpec keySpec = 新しい SecretKeySpec(バイト, "AES"); return keySpec; 2.2. キー 転載する場合は出典を明記してください: http://blog.csdn.net/attilax AES対称暗号化: > のアルゴリズムが矛盾している
、 これが キーであることは当然のことだと考えていますが、実際には、、CryptoJS が実際の キーを計算します。 と IV(新しい用語をすべて説明することはできません, 役に立ちません私に聞いてください、私もわかりません -_-") 5 つのモード: CBC 、CFB、ECB、OFB、PCBC モードとパディングなしで AES アルゴリズムを取得する場合、デフォルトで ECB/PKCS5Padding が使用されます。 モード 詳細セキュリティ 、別のモードの方が安全である可能性があります。 。 。 ECB: 暗号文を同じ長さのブロックに分割し (欠落補完)、個別に暗号化して出力します。一つ一つ暗号文を作っていきます。 利点: 1.単純; 2.並列コンピューティングに役立ちます。 エラーは送信されません。 : はプレーン テキスト モードを非表示にできません。 平文に対する可能性のあるアクティブな攻撃 5.2. 3.2 CBC
利点: 1.積極的に攻撃するのは容易ではない、セキュリティECB よりも優れている、 は長いパケットの送信に適しています 、 は SSL 、 IPSec 標準。 欠点: 1.並列には役に立たない計算; 2.エラーの伝播; 3.初期化ベクトルが必要ですIV 1.隠し平文モード; 2.ブロック暗号をストリーム モードに変換 ; 3.パケットより小さいデータを時間内に暗号化して送信できます; 欠点: 1.並列計算; 2.平文に対する積極的な攻撃が可能です; 3.エラー送信: 1 つの平文ユニットが破損し、複数のユニットに影響を及ぼします ; 1.隠しプレーンテキストモード ; 2.ストリーム モードに変換されたブロック暗号; 3.パケットより小さいデータを時間内に暗号化して送信できます; 欠点: 1.並列コンピューティングには適さない; 2.エラー送信: 1 つの平文ユニットへの損傷は複数のユニットに影響します; 3.唯一のIV; 🎜> は通常 16 バイトを 1 つのブロックとして暗号化し、ブロック全体を暗号化します。入力文字列が 16 バイトでは足りない場合は、ビット PKCS5Padding: パディングの原則は、長さが 16 バイト未満の場合、 までパディングする必要があるということです。 16 バイト、補数 (16-len)(16-len) 例: 123このセクション文字列は 3 バイト、16- 3 = 13, を埋めた後の値は次のとおりです: 123+13 10 進数 13, 文字列の長さがちょうど 16 バイトの場合、16 バイトの 10 進数 16。 CryptoJS は、DES 暗号化、デフォルト モード、および を実行します。 メソッドは、Java のデフォルトとは異なります。 は ECB モードを使用する必要があります。 と PKCS5Padding、 ですが、CryptoJS には Pkcs7、気にしないでください 、試してみてください ... NoPadding、PKCS5Padding、ISO10126Padding の 3 種類のパディングをサポートします。 SSL3Padding はサポートされていません。 「NONE」モードはサポートされていません。 AES/CBC/ISO10126パディング 32 16
1. 暗号化アルゴリズムのパラメータ: Algorithm/Mode/Padding
2. 標準暗号化API利用プロセス
2.1. MD5——16bit パディングキー 、長さが 128 (または他の指定された長さ)
2.3. 操作
著者:: Old Wow's Claw Attilax Ailong、メール:[email protected]
3. Aes暗号原理アーキテクチャ図
ことが判明キーを指定したことです の方法が間違っています 、は文字列をパラメータとして直接受け取ります
5. 暗号化モード
5.1. Ecb
5.3. OFBモード:
利点: 5.4. 3.3 CFBモード:
利点:
パディングメソッド
AES
6.0.1. パディングメソッドアーキテクチャ図
7. アルゴリズム/モード/ 比較表
8. 暗号化セクション長AES/CBC/NoPadding 16 サポートされていません AES/CBC/PKCS5パディング 32 16