中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ASP.NET MD5和SHA1的加密方法是什么

發布時間:2021-10-28 11:04:11 來源:億速云 閱讀:179 作者:柒染 欄目:編程語言

這篇文章將為大家詳細講解有關ASP.NET MD5和SHA1的加密方法是什么,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

ASP.NET MD5和SHA1加密方法有哪些呢?首先我們來看看什么是MD5?MD5的全稱是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest開發出來,經md2、md3和md4發展而來。它的作用是讓大容量信息在用數字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個任意長度的字節串變換成一定長的大整數)。不管是md2、md4還是md5,它們都需要獲得一個隨機長度的信息并產生一個128位的信息摘要。

加密哈希函數將任意長度的二進制字符串映射為固定長度的小型二進制字符串。加密哈希函數有這樣一個屬性:在計算上不大可能找到散列為相同的值的兩個不同的輸入;也就是說,兩組數據的哈希值僅在對應的數據也匹配時才會匹配。數據的少量更改會在哈希值中產生不可預知的大量更改。所以你很難從加密后的文字中找到蛛絲馬跡。

ASP.NET SHA1加密中的SHA1是什么呢?SHA1的全稱是Secure Hash Algorithm(安全哈希算法)

MD5 算法的哈希值大小為 128 位。而SHA1 算法的哈希值大小為 160 位。兩種算法都是不可逆。

雖說2004年8月17日的美國加州圣巴巴拉的國際密碼學會議(Crypto’2004)上,來自中國山東大學的王小云教授做了破譯MD5、HAVAL-128、 MD4和RIPEMD算法的報告,公布了MD系列算法的破解結果。宣告了固若金湯的世界通行密碼標準MD5的堡壘轟然倒塌,引發了密碼學界的軒然大波。但是我覺得對于我們做普通的軟件來說,這個加密安全程度已經足夠使用了。

ASP.NET MD5和SHA1加密方法的概念介紹過了,現在來看看具體的類有哪些呢?

我們平常用的最多的無非就是加密用戶密碼,把加密好的密碼存儲到數據庫中,進行密碼比較的時候,把用戶輸入的密碼再進行加密,然后與數據庫中的密文進行比較。至于asp.net類中是如何實現加密算法的,這個我們不需要關心,會用就行了。

下面就是Asp.net中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這里我舉的例子是以MD5為例,SHA1大致相同,只是使用的類不一樣。

ASP.NET MD5和SHA1加密之MD5 相關類:

System.Security.Cryptography.MD5

System.Security.Cryptography.MD5CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")

ASP.NET MD5和SHA1加密之SHA1相關類:

System.Security.Cryptography.SHA1

System.Security.Cryptography.SHA1CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")

方法如下:(用的vs2005)

/**//// <summary>   /// 方法一:通過使用 new 運算符創建對象   /// </summary>   /// <param name="strSource">需要加密的明文</param>   /// <returns>返回16位加密結果,該結果取32位加密結果的第9位到25位</returns>   public string Get_MD5_Method1(string strSource)   {    //new    System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();     //獲取密文字節數組    byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));     //轉換成字符串,并取9到25位    string strResult = BitConverter.ToString(bytResult, 4, 8);    //轉換成字符串,32位    //string strResult = BitConverter.ToString(bytResult);     //BitConverter轉換出來的字符串會在每個字符中間產生一個分隔符,需要去除掉    strResult = strResult.Replace("-", "");    return strResult;   }    /**//// <summary>   /// 方法二:通過調用特定加密算法的抽象類上的 Create 方法,創建實現特定加密算法的對象。   /// </summary>   /// <param name="strSource">需要加密的明文</param>   /// <returns>返回32位加密結果</returns>   public string Get_MD5_Method2(string strSource)   {    string strResult = "";     //Create    System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();     //注意編碼UTF8、UTF7、Unicode等的選擇     byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));     //字節類型的數組轉換為字符串    for (int i = 0; i < bytResult.Length; i++)    {   //16進制轉換    strResult = strResult + bytResult[i].ToString("X");    }    return strResult;    }       /**//// <summary>    /// 方法三:直接使用HashPasswordForStoringInConfigFile生成    /// </summary>    /// <param name="strSource">需要加密的明文</param>   /// <returns>返回32位加密結果</returns>    public string Get_MD5_Method3(string strSource)    {    return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");    }

這些加密函數都是在服務器端執行,也就是說,當用戶輸入密碼后,從客戶端到服務器端傳輸時,用戶的密碼沒有任何保護,很危險。銀行的做法是在客戶端安裝ActiveX控件,在客戶端就把一些重要信息進行加密,再發送。這個偶就不會拉,很希望能學習學習做這種ActiveX控件。

ASP.NET MD5和SHA1加密的基本情況就介紹到這里。

關于ASP.NET MD5和SHA1的加密方法是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桐城市| 澄城县| 钦州市| 外汇| 根河市| 公主岭市| 徐汇区| 平定县| 宜兰县| 晋宁县| 雷州市| 上杭县| 丹凤县| 揭东县| 泗阳县| 岳阳县| 建平县| 宁明县| 南投县| 水富县| 沽源县| 永嘉县| 潍坊市| 文安县| 石景山区| 瑞金市| 奉节县| 垫江县| 包头市| 西华县| 聂荣县| 孝义市| 乌鲁木齐市| 开远市| 民权县| 平度市| 涞源县| 吴堡县| 莱阳市| 水富县| 呼伦贝尔市|