您希望在计算机上保存一些机密信息吗?如果是,本文就为您介绍如何进行加密!加密技术就是将有意义的字符编码成无意义的字符,使不应该访问这些数据的人员无法读取它们。加密技术已经存在很多年了,甚至远在计算机诞生之前就已经存在了。随着计算机的出现,在计算机领域应用加密技术可以生成几乎牢不可破的代码。Microsoft 在 Windows 95 中开发并分发了加密 API。使用 Microsoft .NET,新创建的类可以将这些复杂的算法打包到非常易于使用的属性和方法中。
散列简介
如果您只是不想让别人窃取您的密码,那么可以为密码数据创建一个散列。散列是一种单向算法,一旦数据被转换,将无法再获得其原始值。大多数开发人员使用数据库存储密码。但是,在数据库中查找用户数据的人员也能够看到这些密码。不过,您可以使用散列算法对密码进行加密,然后再将其存储在数据库中。用户输入密码后,您可以再次使用散列算法对其进行解密,然后将其与存储在数据库中的散列进行比较。散列的缺点之一是,即使原始数据只发生一个小小的改动,数据的散列也会发生非常大的变化。Pork 和 Porky 这两个单词非常相似,但使用散列算法加密后的结果却相去甚远。您可能根本看不出二者之间有什么相似之处。
.NET 开发人员可以使用多种散列算法类。最常用的是 SHA1 和 MD5。下面我们看一下如何为“Paul”这样的普通字符串生成散列,使任何人都无法识别它。
使用 SHA1 生成散列
我们创建一个新例程,然后使用它为字符串“Paul”生成散列。在 Visual Studio® .NET 中打开一个新的 Windows 应用程序,在窗体上放置一个命令按钮。当该命令按钮上发生 Click 事件时,将调用名为 HashText() 的方法。您可以将以下代码添加到该窗体中,看一下此散列算法的实际效果。编写下列代码之前,需要导入命名空间 System.Security.Cryptography。
Private Sub HashText(ByVal TextToHash As String)
Dim SHA1 As SHA1CryptoServiceProvider
Dim bytValue() As Byte
Dim bytHash() As Byte
' 创建新的加密服务提供程序对象
SHA1 = New SHA1CryptoServiceProvider
' 将原始字符串转换成字节数组
bytValue = _
System.Text.Encoding.UTF8.GetBytes(TextToHash)
' 计算散列,并返回一个字节数组
bytHash = SHA1.ComputeHash(bytValue)
SHA1.Clear()
' 返回散列值的 Base64 编码字符串
Debug.WriteLine(Convert.ToBase64String(bytHash))
End Sub
您可以传递不同的字符串值来调用该例程,查看散列值的变化。例如,如果将字符串“Paul”传递给该例程,Debug(调试)窗口将显示以下文本:
w2h6uYgMJt/nq5ZqihcBteAXwv8=
现在,将此过程中的输入值更改为“Pauly”。您将看到以下输出结果:
proywxJ0znMpGF5sbB18+7GSAsM=