目前,对文件加密主要有身份验证式密码加密和文件内容加密两种方式,前者容易被破解,后者相对比较安全。针对目前的加密方法“防频度统计法”破解能力较弱的特点,基于L0gistic混沌映射,我们提出了密钥以明文的不同而不同的随机生成法和加密算法的随机调用技术,从而提高了文件加密的可靠性。
一、数据加密的原理
所谓加密就是把有序的可理解的数据变换成无序的不可理解的数据,从而提高其在使用、保存和传送等环节上的安全性的过程。保密通信机理如图1所示。
加密过程可表示为:C= Ek( M);解密过程可表示为:M= Dk(C)。M为明文;K为密钥;C为通过加密后的密文;E,D分别为加密算法和解密算法。
二、文件加密、解密的原理
从本质上来说,计算机中的文件可以看成是从文件头到文件尾的字节的集合.无论是DOS下的文件还是WINDOWS下的文件;无论是有文件头的文件还是没有文件头的;无论是可执行文件还是非可执行文件,都可以只是将它们看成字节流。要对文件加密,使得加密后的文件面目全非,其实就是要将文件的每个字节看成明文,然后用特定的密钥在加密算法的作用下将明文处理成密文。这样被加密后的文件的内容被破坏,不能正常使用,达到了加密的效果。
对文件加密和解密的示意图如图2所示。
三、混沌映射原理
混沌映射具有很好的性质,即非常相近的初始条件在进行了一定次数的迭代以后会生成两个截然不同的序列;不可由序列的本身预测将产生的下一个数值;而且生成的序列具有白噪声性,即等概率地分布在值域上。由于这些良好的性质,它非常适合于文件加密。
L0gistic迭代公式如下:
其中,参数a∈(0,4);X(n)∈(O,1),n=0,1,2,…。
由该映射产生的序列将呈现出混沌态。由于要将构成文件的一个一个字节加密,所以对生成的实数的集合{X(n)}还要处理成由整数构成的伪随机序列,从而用这些数做加密密钥或者加密算法的随机选择数。
四、基于混沌映射的多随机性文件加密算法
1、文件加密的要求
1)能对基于DOS和WINDOWS的文件加密。
2)对同一个文件,每次加密时,输入的密码不同,则采用不同的加密算法来加密。
3)对构成文件的一个一个字节加密时,要求密钥不同,从而避免被“频度统计法”解密。
4)要区分加密,对有文件头的,只加密前100个字节;对没有文件头的数据文件,全文加密。
2、常用加密算法
对字节流的加密和解密其实就是有规律地破坏和恢复数据,为了实现多种加密方法的随机调用,特设计如下几种加密方法。
1)加减法
将每个字节看成(0~255)之间的一个数,加密时将每个字节加M,解密时将每个字节减M,当然要考虑不能溢出。
2)求反法
将每个字节求反。变成其反码。
3)移位法
将每个字节循环左移M位。
4)替代法
将(0~255)这256个数构造一个换码表,形成一一对应的关系,加密时换码,解密时反换码。
5)异或法
将每个字节跟一个特定的字节M异或,解密时,再跟M异或就还原了。
6)错序文件头法
对于只加密文件头的情况,只要破坏了文件头中各字节的排列顺序,其结构就被破坏,从而达到加密的目的。如将奇偶字节交换位置。
3、加密方法的随机性实现
为了防止别人用“频度统计”的方法解密被加密的文件,对文件加密时,加密算法要随机调用。
本文基于L0gistic迭代公式混沌映射机制,加密算法的随机调用的思想为:
1)由用户输入的密码生成实数a和X(0);
2)利用公式迭代1 00次,求得X (IOO);
3)求得X (IOO)的小数点后的4,5,6位组成的整数Y;
4) Z=Y mc)cl 6,即将Y对6取余数,得到小于6的整数Z;
5)Z就是所求得的用以选择加密算法的伪随机数,0对应算法1;1对应算法2;依次类推。
4、密钥的随机性实现
密码和密钥是不同的,密码是用户对文件加密和解密的一个保密的字符串;密钥是由密码生成的一个在对明文加密过程中起作用的字符串。
假设对一个含文件头的文件加密,只加密前100个字节,要采用异或的方法加密。
为了防止有人对加密后的文件内容按照“频度统计法”解密,对每个字节加密的密钥字符应该不同,为此采用了基于L0gistic混沌影射的密钥生成方法:
1)由用户输入的密码生成实数a和X(0);
2)利用公式迭代2000次求得X (2000);
3)求得X( 2000)的小数点后的4,5,6位组成的整数Y;
4) Z=Y mc)cl 256,即将Y对256取余数,得到小于255的整数Z;
5)Z就是所求得的对第一个字节进行异或加密的密钥;
6)对X( 2000)再迭代5次,继续3,4步求得的Z就是对第二个字节进行异或的密钥;
7)对X( 2005)再迭代5次,继续3,4步求得的Z就是对第三个字节进行异或的密钥;
8)依次类推。
这样对100个字节虽然都是采用异或的方法加密,但是因为每个字节的密钥是各不相同的,所以加密后的密文没有规律可言,基本上不可能被解密。
5、密钥的传递
由于采用了对称加密机制,即加密和解密的密码是相同的,那么解密的时候必须知道加密时候的密码,只有密码正确才能解密。为此必须将加密时的密码(当然要做简单加密,防止别人用16进制工具查看文件中的字符串)保存在某个地方,以便解密时,将输入的解密密码和加密密码对比。
本文将处理过的密码加到被加密文件的尾部,又因为不能将未加密的文件错误解密,所以在被加密文件的尾部还增加了加密标志“#JIAMI#’’,形成了被加密文件的特定文件尾结构,如图3所示。
这样,每个被加密的文件处理后的密码和加密标志都追加到了尾部,解密时,只有判断出是被加密的文件并且用户输入的密码正确才解密,从而保证了解密程序不会因误操作而破坏那些没有加密的文件。
6、具体实现
本文件加密解密软件采用了VB编制,界面简洁友好,能实现各种文件的加密和解密,并且加密和解密的速度适中,能满足用户要求。加密后的文件,有文件头的不能再被相应的应用程序打开;没有文件头的纯数据文件被打开后都是乱码。达到了加密的目的。
小知识之字节流字节流(byte stream)是一种比特流,不过里面的比特被打包成一个个我们叫做字节(Bytes)的单位。
电子文档管理系统的重要性:企业数字化转型的得力助手
在这个智能信息爆炸的时代,数据成为了企业最宝贵的资产之一。如何有效地管理和使用这种信息,已成为每个企业必须面对的重要课题。电子文档管理系统是解决这一问题的关键工具。今日,我们将探讨电子文档管理系统的重要性。在热点话题中,我们经常听到数据泄漏、信息安全等事件。这些事件不仅给企业带来了极大的经济损失,并且严重影响到企业的声...
it资产管理系统:IT资产大管家
在这个智能飞速发展的时代,公司的IT资产如同无形金矿,非常有价值。可是您有没有经历过这种困扰:IT资产种类繁多,数量庞大,管理耗时费力,还常常担忧数据安全和合规性?别担心,今天就给大家介绍一个IT资产管家——安企神IT资产管理系统。一、IT资产管理,为何如此重要?随着企业业务的不断增加,IT资产的数量和种类也在增加。这...
PHP线上加密解密:确保数据安全的有效途径
在如今智能化快速发展的时代,数据安全成为了人或单位不可忽视的重要话题。据最新统计,过去一年超出50%的企业遭到黑客入侵,数据泄露事件高发,给企业信誉和经济损失导致双重打击。在这种情况下,PHP线上加密解密技术的发展至关重要,既能提升数据安全性,又能帮助企业有效防范潜在威胁。一、PHP在线加密解密是什么意思?PHP是一种...
U盘管理工具大曝光:管理便捷,安全无忧!
在这个信息爆炸的时代,U盘已经成为我们日常生活中不可或缺的小帮手。不论是工作材料的备份或是学习课件的存储,U盘都以其小巧便携、容积丰富的特征受到大家的喜爱。但是,随着U盘的广泛使用,管理里的不便也随之而来。别担心,下面我就给大家介绍一款优秀的U盘管理工具,使你的U盘管理更安全!一、U盘管理,为何这么重要?想象一下,你U...
桌面管理软件怎样帮企业提高管理效益?
近日,一家知名科技公司因为桌面管理不当,造成内部数据泄漏,导致了业内的高度重视。这一事件不但揭露了桌面管理在企业管理中的作用,也催生了对高效安全桌面管理软件的需求。在此背景下,安企神桌面管理软件因其卓越的性能和全面的功能迅速成为很多企业的新宠。一、桌面管理:企业安全高效的基石桌面管理不仅关系到企业日常办公的顺利进行,也...