md5--msdn

 

ContractedBlock.gif ExpandedBlockStart.gif Code
using System;
using System.Security.Cryptography;
using System.Text;

class Example
{
    
// Hash an input string and return the hash as
    
// a 32 character hexadecimal string.
    static string getMd5Hash(string input)
    {
        
// Create a new instance of the MD5CryptoServiceProvider object.
        MD5 md5Hasher = MD5.Create();

        
// Convert the input string to a byte array and compute the hash.
        byte[] data = md5Hasher.ComputeHash(Encoding.Default.GetBytes(input));

        
// Create a new Stringbuilder to collect the bytes
        
// and create a string.
        StringBuilder sBuilder = new StringBuilder();

        
// Loop through each byte of the hashed data 
        
// and format each one as a hexadecimal string.
        for (int i = 0; i < data.Length; i++)
        {
            sBuilder.Append(data[i].ToString(
"x2"));
        }

        
// Return the hexadecimal string.
        return sBuilder.ToString();
    }

    
// Verify a hash against a string.
    static bool verifyMd5Hash(string input, string hash)
    {
        
// Hash the input.
        string hashOfInput = getMd5Hash(input);

        
// Create a StringComparer an comare the hashes.
        StringComparer comparer = StringComparer.OrdinalIgnoreCase;

        
if (0 == comparer.Compare(hashOfInput, hash))
        {
            
return true;
        }
        
else
        {
            
return false;
        }
    }


    
static void Main()
    {
        
string source = "Hello World!";

        
string hash = getMd5Hash(source);

        Console.WriteLine(
"The MD5 hash of " + source + " is: " + hash + ".");

        Console.WriteLine(
"Verifying the hash");

        
if (verifyMd5Hash(source, hash))
        {
            Console.WriteLine(
"The hashes are the same.");
        }
        
else
        {
            Console.WriteLine(
"The hashes are not same.");
        }

    }
}
// This code example produces the following output:
//
// The MD5 hash of Hello World! is: ed076287532e86365e841e92bfc50d8c.
// Verifying the hash
// The hashes are the same.

 

 

ContractedBlock.gif ExpandedBlockStart.gif Code
using System;
using System.Security.Cryptography;
using System.Text;

class Example
{
    
// Hash an input string and return the hash as
    
// a 32 character hexadecimal string.
    static string getMd5Hash(string input)
    {
        
// Create a new instance of the MD5CryptoServiceProvider object.
        MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();

        
// Convert the input string to a byte array and compute the hash.
        byte[] data = md5Hasher.ComputeHash(Encoding.Default.GetBytes(input));

        
// Create a new Stringbuilder to collect the bytes
        
// and create a string.
        StringBuilder sBuilder = new StringBuilder();

        
// Loop through each byte of the hashed data 
        
// and format each one as a hexadecimal string.
        for (int i = 0; i < data.Length; i++)
        {
            sBuilder.Append(data[i].ToString(
"x2"));
        }

        
// Return the hexadecimal string.
        return sBuilder.ToString();
    }

    
// Verify a hash against a string.
    static bool verifyMd5Hash(string input, string hash)
    {
        
// Hash the input.
        string hashOfInput = getMd5Hash(input);

        
// Create a StringComparer an compare the hashes.
        StringComparer comparer = StringComparer.OrdinalIgnoreCase;

        
if (0 == comparer.Compare(hashOfInput, hash))
        {
            
return true;
        }
        
else
        {
            
return false;
        }
    }


    
static void Main()
    {
        
string source = "Hello World!";

        
string hash = getMd5Hash(source);

        Console.WriteLine(
"The MD5 hash of " + source + " is: " + hash + ".");

        Console.WriteLine(
"Verifying the hash");

        
if (verifyMd5Hash(source, hash))
        {
            Console.WriteLine(
"The hashes are the same.");
        }
        
else
        {
            Console.WriteLine(
"The hashes are not same.");
        }

    }
}
// This code example produces the following output:
//
// The MD5 hash of Hello World! is: ed076287532e86365e841e92bfc50d8c.
// Verifying the hash
// The hashes are the same.

转载于:https://www.cnblogs.com/joe-yang/archive/2009/03/19/1417059.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值