加密功能
2016-05-29 21:53
295 查看
加密有多种方法,我们常见的有:MD5 DES RSA三种方法。
数据加密我们在自考数据库中学习过,其实也比较容易理解,就是为了达到保护数据的目的而将数据通过某种算法转成一段不可读的代码。
MD5算法
第一:明文数据经过散列以后的值是定长的;第二:是任意一段明文数据,经过散列以后,其结果必须永远是不变的。
输入两个不同的明文不会得到相同的输出值,根据输出值,不能得到原始的明文,即其过程不可逆;所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后,把得到的散列值和原始的数据形成一个一对一的映射表,通过比在表中比破解密码的MD5算法散列值,通过匹配从映射表中找出破解密码所对应的原始明文。
它是不可逆的过程,用于登录的时候忘记密码,系统也不知道我们设置的密码,所以如果忘记密码以后只可以通过手机验证来重新设定。
DES算法
加密原理:使用一个 56 位的密钥以及附加的 8 位奇偶校验位(每组的第8位作为奇偶校验位),产生最大 64 位的分组大小。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。这个有点类似于我们通信行业里的传码传信,为了确保信息传递的正确性,需要加入奇偶校验位来验证翻译过来的信息是否正确。
DES算法的入口参数有三个:Key、Data、Mode。其中Key为8个字节共64位,是DES算法的工作密钥;Data也为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:加密或解密。 也可以这样理解:Key为一次函数的斜率,Data为截距。
DES算法是可逆过程,这个可以用于文件传送的时候防止一些人偷看信息。实际应用的使用直接引用算法即可。
加密过程:
加密函数:
解密函数:
RSA算法
数据加密也能用于数字签名的算法。例如要对字符串the art of programming进行加密,RSA算法会提供两个公钥e和n,其值为两个正整数,解密方持有一个私钥d,然后开始加密解密过程过程。
产生密钥很麻烦,受到素数产生技术的限制,因而难以做到一次一密;安全性差;速度慢。
数据加密我们在自考数据库中学习过,其实也比较容易理解,就是为了达到保护数据的目的而将数据通过某种算法转成一段不可读的代码。
MD5算法
第一:明文数据经过散列以后的值是定长的;第二:是任意一段明文数据,经过散列以后,其结果必须永远是不变的。
输入两个不同的明文不会得到相同的输出值,根据输出值,不能得到原始的明文,即其过程不可逆;所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后,把得到的散列值和原始的数据形成一个一对一的映射表,通过比在表中比破解密码的MD5算法散列值,通过匹配从映射表中找出破解密码所对应的原始明文。
它是不可逆的过程,用于登录的时候忘记密码,系统也不知道我们设置的密码,所以如果忘记密码以后只可以通过手机验证来重新设定。
DES算法
加密原理:使用一个 56 位的密钥以及附加的 8 位奇偶校验位(每组的第8位作为奇偶校验位),产生最大 64 位的分组大小。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但最后一个循环不交换。这个有点类似于我们通信行业里的传码传信,为了确保信息传递的正确性,需要加入奇偶校验位来验证翻译过来的信息是否正确。
DES算法的入口参数有三个:Key、Data、Mode。其中Key为8个字节共64位,是DES算法的工作密钥;Data也为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:加密或解密。 也可以这样理解:Key为一次函数的斜率,Data为截距。
DES算法是可逆过程,这个可以用于文件传送的时候防止一些人偷看信息。实际应用的使用直接引用算法即可。
加密过程:
Dim mytxt, EDes, msgtxt As String mytxt = "你好" '加密 '注意KEY和IV只能用英文和数字,des是8个字符 EDes = EncryptDes(mytxt, "12345678", "abcdefgh") msgtxt = "你好" & vbCrLf & "SHE加密" & vbCrLf & EDes MessageBox.Show(msgtxt, "SHE加密") '解密 mytxt = DecryptDes(EDes, "12345678", "abcdefgh") msgtxt = EDes & vbCrLf & "SHE解密" & vbCrLf & mytxt MessageBox.Show(msgtxt, "SHE解密")
加密函数:
Public Function EncryptDes(ByVal SourceStr As String, ByVal myKey As String, ByVal myIV As String) As String '使用的DES对称加密 Dim des As New System.Security.Cryptography.DESCryptoServiceProvider 'DES算法 Dim inputByteArray As Byte() inputByteArray = System.Text.Encoding.Default.GetBytes(SourceStr) des.Key = System.Text.Encoding.UTF8.GetBytes(myKey) 'myKey DES用8个字符,TripleDES要24个字符 des.IV = System.Text.Encoding.UTF8.GetBytes(myIV) 'myIV DES用8个字符,TripleDES要24个字符 Dim ms As New System.IO.MemoryStream Dim cs As New System.Security.Cryptography.CryptoStream(ms, des.CreateEncryptor(), System.Security.Cryptography.CryptoStreamMode.Write) Dim sw As New System.IO.StreamWriter(cs) sw.Write(SourceStr) sw.Flush() cs.FlushFinalBlock() ms.Flush() EncryptDes = Convert.ToBase64String(ms.GetBuffer(), 0, ms.Length) End Function
解密函数:
Public Function DecryptDes(ByVal SourceStr As String, ByVal myKey As String, ByVal myIV As String) As String '使用标准DES对称解密 Dim des As New System.Security.Cryptography.DESCryptoServiceProvider 'DES算法 des.Key = System.Text.Encoding.UTF8.GetBytes(myKey) 'myKey DES用8个字符,TripleDES要24个字符 des.IV = System.Text.Encoding.UTF8.GetBytes(myIV) 'myIV DES用8个字符,TripleDES要24个字符 Dim buffer As Byte() = Convert.FromBase64String(SourceStr) Dim ms As New System.IO.MemoryStream(buffer) Dim cs As New System.Security.Cryptography.CryptoStream(ms, des.CreateDecryptor(), System.Security.Cryptography.CryptoStreamMode.Read) Dim sr As New System.IO.StreamReader(cs) DecryptDes = sr.ReadToEnd() End Function
RSA算法
数据加密也能用于数字签名的算法。例如要对字符串the art of programming进行加密,RSA算法会提供两个公钥e和n,其值为两个正整数,解密方持有一个私钥d,然后开始加密解密过程过程。
产生密钥很麻烦,受到素数产生技术的限制,因而难以做到一次一密;安全性差;速度慢。
相关文章推荐
- HackRF FM 发射机编写
- 线程的休眠
- Archlinux下virtualbox报错'/sbin/rcvboxdrv setup'
- 数据库
- GitHub客户端的基本操作
- React-Native系列Android——Javascript文件加载过程分析
- Linux(CentOS7)设置Tomcat开机启动与内存设置
- CSS盒子模型
- Linux Shell角本中的条件判断
- CSS中position属性的总结使用
- c#上传文件到服务器
- Golang适合高并发场景的原因分析
- 牛腩完结篇
- (41)Spring Boot 使用Java代码创建Bean并注册到Spring中【从零开始学Spring Boot】
- 第13周项目1 (4)
- 组合数学证明
- 定义自己的operator new和operator delete时注意点
- STL算法 排序
- OS X 和 IOS 的图像处理框架 (Core Image)
- 检索自定义属性的信息