现在位置:站长资讯->首页->软件编程
用VB实现数据的加解密算法
时间:2006-9-3 21:12:27 来源: 作者: 编辑: 【关闭

  随着" 计算机应用的普及,信息的安全性越来越受到人们的重视,对数据加" 解密算法的研究也在不断地深入,但一般的加解密算法如" DES和" RSA等过于复杂,且运算速度慢,特别是它的移位操作,对于" VB这样的高级语言实现起来也比较困难。而一般的" MIS(Management " Information System)系统多用高级语言开发,对数据的加密要求不高,因此,研究简易数据加解密算法还是有相当的现实意义。

简易加解密算法要求

  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,两者合成则为一个不可见的字符。


[1] [2]  下一页

发表评论 相关信息
用户:
查看评论
留言:
验证码:
* 请各位网友遵纪守法并注意语言文明。
*《互联网电子公告服务管理规定》
*《全国人大常委会关于维护互联网安全的规定》
 行业新闻
 服务器
 数据库
版权 © 佰网 www.hb666.com 所有 综合门户站点    未经许可不得复制或镜像  
招商热线:0710 -3851666  3858555  售后服务:0710-3422031  传真:0710- 3452881
  佰网数据:0710-3178666   合作 Email:admin@hb666.com   销售Email:666@hb666.com
CEO信箱  客户留言  我要投诉  诚聘英才