zoukankan      html  css  js  c++  java
  • Visual C# 2005中如何产生与比较哈希值开发者在线 Builder.com.cn 更新时间:20080720作者: 来源:

    Visual C# 2005中如何产生与比较哈希值开发者在线 Builder.com.cn更新时间:2008-07-20作者:来源:本文关键词:如何产生C#应用C#

    Visual C# 2005文件IO与数据存取秘诀》节选条款33Visual C# 2005如何实现比较两个文件的内容是否完全相同条款55Visual C# 2005如何让ComboBox控件显示出多个数据源属性条款56C#中为什么我的ComboBox控件在数据绑定时加载速度很慢条款63Visual C# 2005如何连接至Access数据库条款73Visual C# 2005中如何为数据表建立自动编号字段条款100Visual C# 2005中如何使用数据命令执行Transact-SQL语句条款134C#中将DataSet的内容写成XML时如何格式化字段数据条款152C#中当用户尝试删除数据行时如何显示确认对话框条款161Visual C# 2005中如何以程控方式启动默认的浏览器条款163Visual C# 2005中如何产生与比较哈希值 
    借助于System.Security.Cryptography命名空间的密码资源,将非常容易产生与比较哈希值。因为所有的哈希函数都接收类型为 Byte() 的输入,因此可能需要将初始数据转换成一个字节数组才能够为它产生哈希值。欲为一个字符串值建立一个哈希值,请依下列步骤进行:
     
    1、使用Using语句导入System、System.Security、System.Security.Cryptographic与System.Text命名空间,这样一来,您才不需要于程序代码中编写一长串的完整名称:
     

    using System.Drawing;
    using System.Text;
    using System.Windows.Forms;
    using System.Security.Cryptography;
     
    2、声明一个字符串变量来持有您的初始数据,并声明两个字节数组(未定义大小)来持有初始字节与所产生出的哈希值:
     
    string sSourceData;
    byte[] tmpSource;
    byte[] tmpHash;
     
    3、使用 GetBytes() 方法(它是System.Text.ASCIIEncoding类的一部分)将您的初始字符串转换至一个字节数组中:
     

    sSourceData = "MySourceData";

    // 根据初始数据来建立一个字节数组
    tmpSource = ASCIIEncoding.ASCII.GetBytes(sSourceData);
     
    4、通过调用MD5CryptoServiceProvider类的实例的ComputeHash方法来为您的初始数据计算出MD5哈希值。请注意,欲计算出另外一个哈希值,您必须建立该类的另外一个实例。
     

    // 根据初始数据计算出哈希值
    tmpHash = new MD5CryptoServiceProvider().ComputeHash(tmpSource);

     
    5、tmpHash字节数组现在会获取您初始数据的哈希值(128位值=16字节)。将此显示或储存成一个十六进制字符串通常会非常有用,下列程序代码即是进行此项处理:
     

    lblHashResult.Text = sSourceData + "\n" + ByteArrayToString(tmpHash) + "\n";
     
    private string ByteArrayToString(byte[] arrInput)
    {
     StringBuilder sOutput = new StringBuilder(arrInput.Length);

     for (int i = 0; i < arrInput.Length; i++)
     {
      sOutput.Append(arrInput[i].ToString("X2"));
     }

      return sOutput.ToString();
    }

     
    6、通过上述程序代码,您便能够为初始数据产生出哈希值并以一个十六进制字符串来表示。接下来,我
    们要继续说明如何比较两个哈希值。
     
    为初始数据建立哈希值的目的之一,就是要提供一种方式来检查数据是否被更改过,或是不通过实际的值来比较两个值。不论是哪一种情况,您都需要比较两个哈希值。然而,如果两个哈希值皆已储存成十六进制字符串,则比较哈希值的操作将会更加简易。当然,也有可能两个哈希值都是以字节数组的形式存在。
     
    后续步骤的程序代码将延续先前步骤的程序代码,以便示范如何比较两个字节数组。
     
    7、请在建立一个十六进制字符串的地方,紧接着根据新的初始数据建立一个新的哈希值:
     

    sSourceData = "NotMySourceData";
    tmpSource = ASCIIEncoding.ASCII.GetBytes(sSourceData);
     
    byte[] tmpNewHash;
    bool bEqual = false;
     
    tmpNewHash = new MD5CryptoServiceProvider().ComputeHash(tmpSource);
     
    8、比较两个字节数组最直接了当的方式就是通过循环依序处理数组,以便一一比较两数组中的每一个元素。如果有任何元素不相同,或是两数组的大小不相同,则表示两值并不相等:
     

    if(tmpNewHash.Length == tmpHash.Length)
    {
     int i = 0;

     while((i < tmpNewHash.Length) & & (tmpNewHash[i] == tmpHash[i]))
     {
      i += 1;
     }
     
     if(i == tmpNewHash.Length)
     {
      bEqual = true;
     }
    }

    if (bEqual)
    {
     lblHashResult.Text += "这两个哈希值是相同的";
    }
    else
    {
     lblHashResult.Text += "这两个哈希值并不相同";
    }

     
    9、保存与运行您的项目,以便查看根据第一个哈希值所建立的十六进制字符串,并确认新的哈希值是否
    与初始的相同。
     
    完整的程序代码已编写在程序范例CH14_DemoForm008.cs的Load事件处理函数中,请自行参考之。图 14-13所示则是执行结果。

    Visual C 2005中如何产生与比较哈希值开发者在线 Builder.com.cn 更新时间:2008-07-20作者: 来源: - luiweiping-002 - 〖下里巴人〗图 14-13 


  • 相关阅读:
    006——数组(六)array_fill()array_filter()array_flip()array_key_exists()array_keys()
    005——数组(五)array_diff_ukey()array_diff_uassoc()array_intersect()array_intersect_assoc()array_intersect_key()array_intersect_ukey()array_intersect_uassoc()
    004——数组(四)array_search() array_change_key_case() array_chunk() array_combine() array_diff() array_diff_key() array_diff_assoc
    laravel中资源路由的控制器创建方法:
    003——数组(三)count()reset()end()prev()next()current()
    002——数组(二)each() list() implode() explode() in_array()
    001——数组(一)数组知识及foreach函数应用
    JVM内存分配 -Xms128m -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=512m
    tomcat 启动参数 Xms, Xmx, XX:MaxNewSize, XX:PermSize, -XX:MaxPermSize, Djava.awt.headless
    CentOS 7 中firewall-cmd命令
  • 原文地址:https://www.cnblogs.com/zhiji6/p/1649395.html
Copyright © 2011-2022 走看看