.NET MD5 暗号化および復号化コード分析
この記事は主に .NET MD5 の暗号化と復号化コードを詳細に分析します。興味のある方は参考にしてください。
大容量の情報にデジタル署名を使用します。ソフトウェアが秘密キーに署名する前に、秘密キーは機密形式に「圧縮」されます (つまり、任意の長さのバイト文字列が特定の長さの大きな整数に変換されます)。 MD2、MD4、MD5 のいずれであっても、ランダムな長さの情報を取得し、128 ビットのメッセージ ダイジェストを生成する必要があります。これらのアルゴリズムの構造は多かれ少なかれ似ていますが、MD2 の設計は MD4 および MD5 とはまったく異なります。これは、MD4 と MD5 が 32 ビット コンピュータ用に設計されているのに対し、MD2 は 8 ビット マシン用に設計および最適化されているためです。これら 3 つのアルゴリズムの説明と C 言語ソース コードは、インターネット RFC 1321 に詳しく説明されています。これは、1992 年 8 月に Ronald L. Rivest によって IETF に提出された最も権威のある文書です。
コード:string JiaMi = Md5Encrypt(LoginPwd); string JieMi = Md5Decrypt(JiaMi); #region MD5加密 /// <summary> /// MD5加密 /// </summary> /// <param name="strSource">需要加密的字符串</param> /// <returns>MD5加密后的字符串</returns> public static string Md5Encrypt(string strSource) { //把字符串放到byte数组中 byte[] bytIn = System.Text.Encoding.Default.GetBytes(strSource); //建立加密对象的密钥和偏移量 byte[] iv = { 102, 16, 93, 156, 78, 4, 218, 32 };//定义偏移量 byte[] key = { 55, 103, 246, 79, 36, 99, 167, 3 };//定义密钥 //实例DES加密类 DESCryptoServiceProvider mobjCryptoService = new DESCryptoServiceProvider(); mobjCryptoService.Key = iv; mobjCryptoService.IV = key; ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor(); //实例MemoryStream流加密密文件 System.IO.MemoryStream ms = new System.IO.MemoryStream(); CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write); cs.Write(bytIn, 0, bytIn.Length); cs.FlushFinalBlock(); return System.Convert.ToBase64String(ms.ToArray()); } #endregion #region MD5解密 /// <summary> /// MD5解密 /// </summary> /// <param name="Source">需要解密的字符串</param> /// <returns>MD5解密后的字符串</returns> public static string Md5Decrypt(string Source) { //将解密字符串转换成字节数组 byte[] bytIn = System.Convert.FromBase64String(Source); //给出解密的密钥和偏移量,密钥和偏移量必须与加密时的密钥和偏移量相同 byte[] iv = { 102, 16, 93, 156, 78, 4, 218, 32 };//定义偏移量 byte[] key = { 55, 103, 246, 79, 36, 99, 167, 3 };//定义密钥 DESCryptoServiceProvider mobjCryptoService = new DESCryptoServiceProvider(); mobjCryptoService.Key = iv; mobjCryptoService.IV = key; //实例流进行解密 System.IO.MemoryStream ms = new System.IO.MemoryStream(bytIn, 0, bytIn.Length); ICryptoTransform encrypto = mobjCryptoService.CreateDecryptor(); CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read); StreamReader strd = new StreamReader(cs, Encoding.Default); return strd.ReadToEnd(); } #endregion
MD5暗号化方法:
MD5暗号化は、単に平文の一部を使用して、特定の計算方法を通じて暗号文を見つけることを意味します。例: 平文は次のとおりです: abcdefg 一連の操作により、暗号文 7ac66c0f148de9519b8bd264312c4d64
が得られます。これには 2 つの特徴があります: 1. 衝突なし、2. 不可逆。 衝突なしとは:7ac66c0f148de9519b8bd264312c4d64 この暗号文は、この平文の abcdefg からのみ取得できます。また、暗号化後の他の平文の値は 7ac66c0f148de9519b8bd に等しくなりません。 264312c4 d64、つまり、ありませんこれら 2 つ 平文を暗号化すると、同じ暗号文が得られます。
不可逆とは、平文を暗号化して暗号文を取得するが、暗号文を介して平文を取得することはできない。つまり、平文の adcdefg が暗号化できることがわかっている場合は 7ac66c0f148de9519b8bd264312c4d64 を取得できますが、特定のテキストが暗号化されていることがわかっている場合は 7ac66c0f148de9519b8bd264312c4d64 を取得できますが、7ac66c0f148de95 は計算できません。 19b8bd264312c4 このテキスト d64 を暗号化したのは誰ですか?
たとえば、ユーザーが設定したパスワードは abcdefg で、abcdefg が暗号化された後に取得された値 7ac66c0f148de9519b8bd264312c4d64 を保存します。その後、ユーザーが再度ログインするときにパスワード abcdefg を入力するかどうかを比較するにはどうすればよいですか。二つは等しいですか? 暗号化された値を暗号化前の値に変換することはできないため、通常のアプローチは、ユーザーが再度ログインするときに入力したパスワードを再暗号化し、データベースに保存されている値と比較することです。入力されたパスワードが正しいことを意味します。 引用する必要がありますusing System.Web.Security;
FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower();
上記がこの記事の全内容であると幸いです。皆様の学習にお役に立てれば幸いです。また、PHP 中国語 Web サイトをサポートしていただければ幸いです。
.NET MD5 暗号化および復号化コード分析に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。
ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

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

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









C言語では、以下などのエスケープシーケンスを通じて特殊文字が処理されます。\ nはラインブレークを表します。 \ tはタブ文字を意味します。 ESACEシーケンスまたは文字定数を使用して、Char C = '\ n'などの特殊文字を表します。バックスラッシュは2回逃げる必要があることに注意してください。さまざまなプラットフォームとコンパイラが異なるエスケープシーケンスを持っている場合があります。ドキュメントを参照してください。

Cでは、文字列でCharタイプが使用されます。1。単一の文字を保存します。 2。配列を使用して文字列を表し、ヌルターミネーターで終了します。 3。文字列操作関数を介して動作します。 4.キーボードから文字列を読み取りまたは出力します。

c言語のシンボルの使用方法は、算術、割り当て、条件、ロジック、ビット演算子などをカバーします。算術演算子は基本的な数学的操作に使用されます。割り当てと追加、下位、乗算、除算の割り当てには、条件操作に使用されます。ポインター、ファイル終了マーカー、および非数値値。

C言語では、charとwchar_tの主な違いは文字エンコードです。CharはASCIIを使用するか、ASCIIを拡張し、WCHAR_TはUnicodeを使用します。 Charは1〜2バイトを占め、WCHAR_Tは2〜4バイトを占有します。 charは英語のテキストに適しており、wchar_tは多言語テキストに適しています。 CHARは広くサポートされており、WCHAR_TはコンパイラとオペレーティングシステムがUnicodeをサポートするかどうかに依存します。 CHARの文字範囲は限られており、WCHAR_Tの文字範囲が大きく、特別な機能が算術演算に使用されます。

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

C言語では、charタイプの変換は、キャスト:キャスト文字を使用することにより、別のタイプに直接変換できます。自動タイプ変換:あるタイプのデータが別のタイプの値に対応できる場合、コンパイラは自動的に変換します。

Char Arrayは文字シーケンスをC言語で保存し、char array_name [size]として宣言されます。アクセス要素はサブスクリプト演算子に渡され、要素は文字列のエンドポイントを表すnullターミネーター「\ 0」で終了します。 C言語は、strlen()、strcpy()、strcat()、strcmp()など、さまざまな文字列操作関数を提供します。

C言語に組み込みの合計機能はないため、自分で書く必要があります。合計は、配列を通過して要素を蓄積することで達成できます。ループバージョン:合計は、ループとアレイの長さを使用して計算されます。ポインターバージョン:ポインターを使用してアレイ要素を指し示し、効率的な合計が自己概要ポインターを通じて達成されます。アレイバージョンを動的に割り当てます:[アレイ]を動的に割り当ててメモリを自分で管理し、メモリの漏れを防ぐために割り当てられたメモリが解放されます。
