java中完成md5加密解密_java实现md5加密解密 notNET中加密和解密的实现方法
java實現md5加密解密 notNET中加密和解密的實現方法
亦或是旅途風光 7-14
1918℃ 22
【 ee21.cn - ASP.NET 】 .NET將原來獨立的API和SDK合并到一個框架中,這對于程序開發人員非常有利。它將CryptoAPI改編進.NET的System.Security.Cryptography名字空間,使密碼服務擺脫了SDK平臺的神秘性,變成了簡單的.NET名字空間的使用。由于隨著整個框架組件一起共享,密碼服務更容易實現了,現在僅僅需要學習System.Security.Cryptography名字空間的功能和用于解決特定方案的類。
加密和解密的算法 System.Security.Cryptography名字空間包含了實現安全方案的類,例如加密和解密數據、管理密鑰、驗證數據的完整性并確保數據沒有被篡改等等。本文重點討論加密和解密。 加密和解密的算法分為對稱(symmetric)算法和不對稱(asymmetric)算法。對稱算法在加密和解密數據時使用相同的密鑰和初始化矢量,典型的有DES、 TripleDES和Rijndael算法,它適用于不需要傳遞密鑰的情況,主要用于本地文檔或數據的加密。不對稱算法有兩個不同的密鑰,分別是公共密鑰和私有密鑰,公共密鑰在網絡中傳遞,用于加密數據,而私有密鑰用于解密數據。不對稱算法主要有RSA、DSA等,主要用于網絡數據的加密。
加密和解密本地文檔 下面的例子是加密和解密本地文本,使用的是Rijndael對稱算法。 對稱算法在數據流通過時對它進行加密。因此首先需要建立一個正常的流(例如I/O流)。文章使用FileStream類將文本文件讀入字節數組,也使用該類作為輸出機制。 接下來定義相應的對象變量。在定義SymmetricAlgorithm抽象類的對象變量時我們可以指定任何一種對稱加密算法提供程序。代碼使用的是Rijndael算法,但是很容易改為DES或者TripleDES算法。.NET使用強大的隨機密鑰設置了提供程序的實例,選擇自己的密鑰是比較危險的,接受計算機產生的密鑰是一個更好的選擇,文中的代碼使用的是計算機產生的密鑰。 下一步,算法實例提供了一個對象來執行實際數據傳輸。每種算法都有CreateEncryptor和CreateDecryptor兩個方法,它們返回實現ICryptoTransform接口的對象。 最后,現在使用BinaryReader的ReadBytes方法讀取源文件,它會返回一個字節數組。BinaryReader讀取源文件的輸入流,在作為CryptoStream.Write方法的參數時調用ReadBytes方法。指定的CryptoStream實例被告知它應該操作的下層流,該對象將執行數據傳遞,無論流的目的是讀或者寫。 下面是加密和解密一個文本文件的源程序片斷:
namespace com.billdawson.crypto{class TextFileCrypt{public static void Main(string[] args){string file = args[0];string tempfile = Path.GetTempFileName();//打開指定的文件FileStream fsIn = File.Open(file,FileMode.Open,FileAccess.Read);FileStream fsOut = File.Open(tempfile, FileMode.Open,FileAccess.Write);//定義對稱算法對象實例和接口SymmetricAlgorithm symm = new RijndaelManaged();ICryptoTransform transform = symm.CreateEncryptor();CryptoStream cstream = new CryptoStream(fsOut,transform,ryptoStreamMode.Write);BinaryReader br = new BinaryReader(fsIn);// 讀取源文件到cryptostream cstream.Write(br.ReadBytes((int)fsIn.Length),0,(int)fsIn.Length);cstream.FlushFinalBlock();cstream.Close();fsIn.Close();fsOut.Close();Console.WriteLine("created encrypted file {0}", tempfile);Console.WriteLine("will now decrypt and show contents");// 反向操作--解密剛才加密的臨時文件fsIn = File.Open(tempfile,FileMode.Open,FileAccess.Read);transform = symm.CreateDecryptor();cstream = new CryptoStream(fsIn,transform,CryptoStreamMode.Read);StreamReader sr = new StreamReader(cstream);Console.WriteLine("decrypted file text: " + sr.ReadToEnd());fsIn.Close();}}}
加密網絡數據 如果我有一個只想自己看到的文檔,我不會簡單的通過e-mail發送給你。我將使用對稱算法加密它;如果有人截取了它,他們也不能閱讀該文檔,因為他們沒有用于加密的唯一密鑰。但是你也沒有密鑰。我需要使用某種方式將密鑰給你,這樣你才能解密文檔,但是不能冒密鑰和文檔被截取的風險。 非對稱算法就是一種解決方案。這類算法使用的兩個密鑰有如下關系:使用公共密鑰加密的信息只能被相應的私有密鑰解密。因此,我首要求你給我發送你的公共密鑰。在發送給我的途中可能有人會截取它,但是沒有關系,因為他們只能使用該密鑰給你的信息加密。我使用你的公共密鑰加密文檔并發送給你。你??本文由亦或是旅途風光
分享,文章內容系作者個人觀點,不代表21中文網對觀點贊同或支持。
如需轉載,請注明本文地址:http://www.ee21.cn/zw/17306/69120210.html
總結
以上是生活随笔為你收集整理的java中完成md5加密解密_java实现md5加密解密 notNET中加密和解密的实现方法的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 怎么设置java的精度值_Java:如何
- 下一篇: java对象数组覆盖_java – 如何
