用VB实现数据的加解密算法
2008-04-09 04:40:56来源:互联网 阅读 ()
简易加解密算法要求:
1、 算法不宜过于复杂,且具有一定的保密性
2、 对于高级语言很容易能实现
3、 速度快,可以在任何时候、任何地方使用。
4、 加密后的数据能正确地得到解密
鉴于以上特点,从加密的主要方法看,换位法过于简单,特别是对于数据量少的情况很容易由密文猜出明文,替换法则不失为一种行之有效的简易算法。
首先,Windows下的字符集采用Unicode字符集,它容量大,可置换的范围广;其次,在Unicode字符集中,所有字符的内码都占两个字节,不再象DOS下西文字符占一个字节,中文字符占两个字节,这样无论西文还是中文都可以互换。因此,将某个字符的高字节和低字节分别加以运算,生成另外一个0-255之间的数,然后再将它们合成为另一个字符,从而置换数据达到数据加密的作用,解密时则相反。
从各种位运算的特点看,异或运算最适合用于简易加解密运算,因为当一个数A和另一个数B进行异或运算会生成另一个数C,如果再将C和B进行异或运算则C又会还原为A。如:128和253进行异或运算的结果是125,125和253再进行异或运算则结果又是128。其中,128就是要加密的数据,253则是密钥。利用这个特性可以将加密和解密用一个函数实现。用同一密钥进行奇数次运算时,是对数据进行加密运算,当进行偶数次运算时,是对数据进行解密运算。如果对Unicode字符进行这种运算,需要两个密钥,其取值范围为0-255,其中一个用于对高字节加密,一个用于对低字节进行加密,这样对同一字符的加密就有255×255=65025种可能。如果更换密钥后对密文再进行加密,则会有无穷的可能性。如:密钥K1=68,K2=134,则字符A的低字节为65,它和K1异或后为5,A的高字节为0,它和K2异或后还是134,两者合成的字符为"蘅"。再如:"密"的低字节为198,和K1异或后为130,它的高字节为91,和K2异或后为221,两者合成则为一个不可见的字符。
156
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:用DDE创建桌面快捷方式
下一篇:具有微软风格的Explore
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash