當前位置: 首頁>>代碼示例>>C#>>正文


C# MD5CryptoServiceProvider.Dispose方法代碼示例

本文整理匯總了C#中System.Security.Cryptography.MD5CryptoServiceProvider.Dispose方法的典型用法代碼示例。如果您正苦於以下問題:C# MD5CryptoServiceProvider.Dispose方法的具體用法?C# MD5CryptoServiceProvider.Dispose怎麽用?C# MD5CryptoServiceProvider.Dispose使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Security.Cryptography.MD5CryptoServiceProvider的用法示例。


在下文中一共展示了MD5CryptoServiceProvider.Dispose方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GetHash

 public static string GetHash(string text)
 {
     MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
     byte[] hash = md5.ComputeHash(Encoding.UTF8.GetBytes(text));
     StringBuilder Hash = new StringBuilder();
     foreach (byte b in hash)
     {
         Hash.AppendFormat("{0:X2}", b);
     }
     md5.Dispose();
     return Hash.ToString();
 }
開發者ID:Muscipular,項目名稱:osu-BeatmapTool,代碼行數:12,代碼來源:CommonHelper.cs

示例2: Encrypt_static

        /// <summary>
        /// MD5CryptoServiceProvider類的哈希大小為 128 位
        /// 此類型的任何公共static成員都是線程安全的。但不保證所有實例成員都是線程安全的
        /// </summary>
        private static string Encrypt_static(string clearText, Encoding encode)
        {
            MD5 md5 = null;
            try
            {
                byte[] originalBytes = encode.GetBytes(clearText); //Encoding.UTF8.GetBytes(clearText);

                md5 = new MD5CryptoServiceProvider();
                byte[] data = md5.ComputeHash(originalBytes);

                StringBuilder builder = new StringBuilder();
                foreach (var item in data)
                {
                    builder.Append(item.ToString("X2"));
                }

                return builder.ToString();
            }
            catch (ArgumentNullException) { return clearText; }
            catch (EncoderFallbackException) { return clearText; }
            //catch (TargetInvocationException) { return clearText; }
            catch (ObjectDisposedException) { return clearText; }
            catch (InvalidOperationException) { return clearText; }
            catch { return clearText; }
            finally
            {
                if (md5 != null)
                {
                    md5.Clear();
                    md5.Dispose();
                }

                md5 = null;
            }

            //return "";
        }
開發者ID:RoseLiu,項目名稱:OnePieceSolution,代碼行數:41,代碼來源:MD5CspClass.cs

示例3: ComputeHash


//.........這裏部分代碼省略.........
        /// Name of the hash algorithm. Allowed values are: "MD5", "SHA1",
        /// "SHA256", "SHA384", "SHA512", "HMACMD5", "HMACSHA1", "HMACSHA256",
        ///  "HMACSHA512" (if any other value is specified  MD5 will be used). 
        /// 
        /// HMAC algorithms uses Hash-based Message Authentication Code.
        /// The HMAC process mixes a secret key with the message data, hashes 
        /// the result with the hash function, mixes that hash value with 
        /// the secret key again, and then applies the hash function
        /// a second time. HMAC hashes are fixed lenght and generally
        /// much longer than non-HMAC hashes of the same type.
        /// 
        /// https://msdn.microsoft.com/en-us/library/system.security.cryptography.hmacsha256(v=vs.110).aspx      
        /// 
        /// This value is case-insensitive.
        /// </param>
        /// <param name="saltBytes">
        /// Optional but recommended salt bytes to apply to the hash. If not passed the
        /// raw encoding is used. If salt is nullthe raw algorithm is used (useful for 
        /// file hashes etc.) HMAC versions REQUIRE that salt is passed.
        /// </param>
        /// <param name="useBinHex">if true returns the data as BinHex byte pair string. Otherwise Base64 is returned.</param>
        /// <returns>
        /// Hash value formatted as a base64-encoded or BinHex stringstring.
        /// </returns>
        public static string ComputeHash(byte[] byteData,
            string hashAlgorithm,
            byte[] saltBytes,
            bool useBinHex = false)
        {
            if (byteData == null)
                return null;

            // Convert plain text into a byte array.
            byte[] plainTextWithSaltBytes;

            if (saltBytes != null)
            {
                // Allocate array, which will hold plain text and salt.
                plainTextWithSaltBytes =
                    new byte[byteData.Length + saltBytes.Length];

                // Copy plain text bytes into resulting array.
                for (int i = 0; i < byteData.Length; i++)
                    plainTextWithSaltBytes[i] = byteData[i];

                // Append salt bytes to the resulting array.
                for (int i = 0; i < saltBytes.Length; i++)
                    plainTextWithSaltBytes[byteData.Length + i] = saltBytes[i];
            }
            else
                plainTextWithSaltBytes = byteData;

            HashAlgorithm hash;

            // Make sure hashing algorithm name is specified.
            if (hashAlgorithm == null)
                hashAlgorithm = "";

            // Initialize appropriate hashing algorithm class.
            switch (hashAlgorithm.ToUpper())
            {
                case "SHA1":
                    hash = new SHA1Managed();
                    break;
                case "SHA256":
                    hash = new SHA256Managed();
                    break;
                case "SHA384":
                    hash = new SHA384Managed();
                    break;
                case "SHA512":
                    hash = new SHA512Managed();
                    break;
                case "HMACMD5":
                    hash = new HMACMD5(saltBytes);
                    break;
                case "HMACSHA1":
                    hash = new HMACSHA1(saltBytes);
                    break;
                case "HMACSHA256":
                    hash = new HMACSHA256(saltBytes);
                    break;
                case "HMACSHA512":
                    hash = new HMACSHA512(saltBytes);
                    break;
                default:
                    // default to MD5
                    hash = new MD5CryptoServiceProvider();
                    break;
            }

            byte[] hashBytes = hash.ComputeHash(plainTextWithSaltBytes);

            hash.Dispose();

            if (useBinHex)
                return BinaryToBinHex(hashBytes);

            return Convert.ToBase64String(hashBytes);
        }
開發者ID:RickStrahl,項目名稱:WestwindToolkit,代碼行數:101,代碼來源:Encryption.cs

示例4: GetMD5

 /// <summary>
 ///     根據文件路徑得到文件的MD5值
 /// </summary>
 /// <param name="filePath">文件的路徑</param>
 /// <returns>MD5值</returns>
 public static string GetMD5(string filePath)
 {
     try
     {
         var get_file = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read);
         var md5 = new MD5CryptoServiceProvider();
         var hash_byte = md5.ComputeHash(get_file);
         var resule = System.BitConverter.ToString(hash_byte);
         resule = resule.Replace("-", "");
         md5.Clear();
         md5.Dispose();
         get_file.Close();
         get_file.Dispose();
         return resule;
     }
     catch (Exception e) {
         return e.ToString();
     }
 }
開發者ID:FarseerNet,項目名稱:Farseer.Net.Utils,代碼行數:24,代碼來源:Files.cs

示例5: MD5Stream

 public static string MD5Stream(System.IO.Stream stream)
 {
     System.Security.Cryptography.MD5CryptoServiceProvider md5 = null;
     string resule = string.Empty;
     if (stream != null)
     {
         try
         {
             md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
             byte[] hash = md5.ComputeHash(stream);
             resule = System.BitConverter.ToString(hash);
             resule = resule.Replace("-", "");
         }
         finally
         {
             if (md5 != null)
             {
                 md5.Dispose();
             }
         }
     }
     stream.Close();
     return resule;
 }
開發者ID:super860327,項目名稱:firstwpftest,代碼行數:24,代碼來源:ChatComponent.xaml.cs

示例6: MD5File

        public string MD5File(string fileName)
        {
            if(fileName.IsNull())
                throw new ArgumentNullException("fileName");

            byte[] retVal;

            using(var file = new FileStream(fileName, FileMode.Open))
            {
                var md5 = new MD5CryptoServiceProvider();
                retVal = md5.ComputeHash(file);
            #if false
                md5.Dispose();
            #endif
            }

            var sb = new StringBuilder();

            if(!retVal.IsNull())
            {
                for(var i = 0; i < retVal.Length; i++)
                    sb.Append(retVal[i].ToString("x2"));
            }

            return sb.ToString();
        }
開發者ID:Schumix,項目名稱:Schumix2,代碼行數:26,代碼來源:Utilities.cs

示例7: Md5

        public string Md5(string value)
        {
            if(value.IsNull())
                throw new ArgumentNullException("value");

            var x = new MD5CryptoServiceProvider();
            var data = Encoding.UTF8.GetBytes(value);
            data = x.ComputeHash(data);
            #if false
            x.Dispose();
            #endif
            var ret = string.Empty;

            for(var i = 0; i < data.Length; i++)
                ret += data[i].ToString("x2").ToLower();

            return ret;
        }
開發者ID:Schumix,項目名稱:Schumix2,代碼行數:18,代碼來源:Utilities.cs

示例8: Verify

        /// <summary>
        /// Computes the hash for the specified stream and compares
        /// it to the value in this object. CRC hashes are not supported 
        /// because there is no built-in support in the .net framework and
        /// a CRC implementation exceeds the scope of this project. If you
        /// attempt to Verify() a CRC hash a NotImplemented() exception will
        /// be thrown.
        /// </summary>
        /// <param name="istream">The stream to compute the hash for</param>
        /// <returns>True if the computed hash matches what's stored in this object.</returns>
        public bool Verify(Stream istream) {
            if (IsValid) {
                HashAlgorithm hashAlg = null;

                switch (m_algorithm) {
                    case FtpHashAlgorithm.SHA1:
                        hashAlg = new SHA1CryptoServiceProvider();
                        break;
#if !NET2
                    case FtpHashAlgorithm.SHA256:
                        hashAlg = new SHA256CryptoServiceProvider();
                        break;
                    case FtpHashAlgorithm.SHA512:
                        hashAlg = new SHA512CryptoServiceProvider();
                        break;
#endif
                    case FtpHashAlgorithm.MD5:
                        hashAlg = new MD5CryptoServiceProvider();
                        break;
                    case FtpHashAlgorithm.CRC:
                        throw new NotImplementedException("There is no built in support for computing CRC hashes.");
                    default:
                        throw new NotImplementedException("Unknown hash algorithm: " + m_algorithm.ToString());
                }

                try {
                    byte[] data = null;
                    string hash = "";

                    data = hashAlg.ComputeHash(istream);
                    if (data != null) {
                        foreach (byte b in data) {
                            hash += b.ToString("x2");
                        }

                        return (hash.ToUpper() == m_value.ToUpper());
                    }
                }
                finally {
#if !NET2 // .NET 2.0 doesn't provide access to Dispose() for HashAlgorithm
                    if (hashAlg != null)
                        hashAlg.Dispose();
#endif
                }
            }

            return false;
        }
開發者ID:marioricci,項目名稱:erp-luma,代碼行數:58,代碼來源:FtpHash.cs

示例9: ToMD5Hash

        /// <summary>
        /// Returns the MD5 hash string of the input string.
        /// </summary>
        /// <param name="input">The input.</param>
        /// <returns>The MD5 hash string of the input string.</returns>
        public static string ToMD5Hash(this string input)
        {
            var cryptoServiceProvider = new MD5CryptoServiceProvider();

            var newdata = Encoding.Default.GetBytes(input);

            var encrypted = cryptoServiceProvider.ComputeHash(newdata);

            cryptoServiceProvider.Dispose();

            return BitConverter.ToString(encrypted).Replace("-", string.Empty).ToLower();
        }
開發者ID:KaraokeStu,項目名稱:LeadPipe.Net,代碼行數:17,代碼來源:StringExtensions.cs


注:本文中的System.Security.Cryptography.MD5CryptoServiceProvider.Dispose方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。