易语言CNA算法实现快速加密解密文件的代码
CNA文件加解密数据算法
.版本 2 .支持库 spec .支持库 iext .程序集 窗口程序集_启动窗口 .子程序 __启动窗口_创建完毕 .局部变量 code, 字节集, , , 加密密码 .局部变量 test, 字节集, , , 要加密码的数据字节集 .局部变量 i, 整数型, , , 查看反馈信息 ' 简单例子 test = 到字节集 (“aaaaaaa aaa.*#(中。329}@#¥”) code = 到字节集 (“中。有 3a#”) CNA数据 (test, code, 1) 调试输出 (到文本 (test)) CNA数据 (test, code, ) 调试输出 (到文本 (test)) ' 直接用一个文件进行加解密测试。功能完整的。 .子程序 CNA数据, 整数型, , 返回数1表示加密完成,返回0表示解密完成,返回10表示加密或解密码失败 .参数 数据集, 字节集, 可空, 要加密的数据集 .参数 密码集, 字节集, 可空, 要加密的密码集 .参数 方式, 整数型, 可空, 1是加密,0或省略是解密 .局部变量 j, 整数型, , , 计次变量 .局部变量 i, 整数型, , , 密码集长度 .局部变量 k, 整数型, , , 数据集长度 .局部变量 lk, 整数型, , , 计算对换对换位置变量 .局部变量 t, 整数型, , , 计算对换对换位置变量 .局部变量 对换位置组, 整数型, , "0", 存放8个位置数据 .局部变量 临时变量, 字节集, , , 临时存放变量 .局部变量 密码叠加量, 整数型, , , 密码叠加变量 .局部变量 随机数, 整数型, , , 随机变量 .局部变量 随机变量集, 字节集, , , 随机变量字节集 .局部变量 单个对换位置, 整数型, , , 存放单个对换位置 ' 限制只加密大于大于或等于10字节以上长度的文件,密码可以和文件一样长,如果比文件长,那多出部分只能累加到密码叠加量里,不能在数据集加密中进行混合 ' 小于10字节的文件可自行调整参数和算法 .如果真 (方式 = 1 且 取字节集长度 (数据集) ≥ 10 且 取字节集长度 (密码集) ≥ 1) ' >>>>>>>>>>>>>加密开始 ' ----------------------------------(1)计算密码叠加量 j = 取字节集长度 (密码集) .计次循环首 (j, i) 密码叠加量 = 密码集 [i] + 密码叠加量 + i × 15 .计次循环尾 () lk = 密码叠加量 ' ---用于计算对换位置时使用 ' ----------------------------------(2)引入固定8位数随机变量 置随机数种子 () 随机数 = 取随机数 (10000000, 98999999) ' ----------------------------------(3)开始数据集加密 j = 取字节集长度 (密码集) .计次循环首 (取字节集长度 (数据集), i) ' ------开始加密数据 数据集 [i] = 数据集 [i] + 密码集 [j] + 密码叠加量 + 随机数 j = j - 1 .如果真 (j = 0) j = 取字节集长度 (密码集) .如果真结束 .计次循环尾 () ' ----------------------------------(4)开始把随机数转换随机变量集加密,再合并到数据集中 随机数 = 随机数 + 密码叠加量 ' ------第一次简单混合加密 随机变量集 = 到字节集 (到文本 (随机数)) j = 取字节集长度 (密码集) .计次循环首 (取字节集长度 (随机变量集), i) ' ------开始第二次加密随机变量集 随机变量集 [i] = 随机变量集 [i] + 密码集 [j] + 密码叠加量 j = j - 1 .如果真 (j = 0) j = 取字节集长度 (密码集) .如果真结束 .计次循环尾 () 数据集 = 数据集 + 随机变量集 ' ------数据集和随机变量集合并 ' ----------------------------------(5)通过对数据集长度和密码叠加变量的比例算法求出对换位置 t = 取字节集长度 (数据集) .计次循环首 (8, i) ' ------先通过和密码叠加变量计算出对应位置 加入成员 (对换位置组, t × lk ÷ (lk + t)) t = t - 1.69 lk = lk × 0.459 .计次循环尾 () ' ----------------------------------(6)开始对换随机变量集在数据集里的位置 k = 取字节集长度 (数据集) 临时变量 = 取空白字节集 (1) .计次循环首 (8, i) ' ------ 开始对换 单个对换位置 = 对换位置组 [i] 临时变量 [1] = 数据集 [单个对换位置] 数据集 [单个对换位置] = 数据集 [k] 数据集 [k] = 临时变量 [1] k = k - 1 .计次循环尾 () 返回 (1) .如果真结束 .如果真 (方式 = 0 且 取字节集长度 (数据集) ≥ 10 且 取字节集长度 (密码集) ≥ 1) ' --------------------解密 ' ----------------------------------(1)计算密码叠加量,和加密部分(1)一样 j = 取字节集长度 (密码集) .计次循环首 (j, i) 密码叠加量 = 密码集 [i] + 密码叠加量 + i × 15 .计次循环尾 () lk = 密码叠加量 ' ---用于计算对换位置时使用 ' ----------------------------------(2)通过对数据集长度和密码叠加变量的比例算法求出对换位置,和加密码部分(5)一样 t = 取字节集长度 (数据集) .计次循环首 (8, i) 加入成员 (对换位置组, t × lk ÷ (lk + t)) t = t - 1.69 lk = lk × 0.459 .计次循环尾 () ' ----------------------------------(3)开始对换随机变量集在数据集里的位置,并把数据集和随机变量集切分出来,对换位置和加密部分(6)略有不同 k = 取字节集长度 (数据集) - 7 ' ------ 开始反向对换 临时变量 = 取空白字节集 (1) .计次循环首 (8, i) 单个对换位置 = 对换位置组 [9 - i] ' ------ 开始反向对换 临时变量 [1] = 数据集 [单个对换位置] 数据集 [单个对换位置] = 数据集 [k] 数据集 [k] = 临时变量 [1] k = k + 1 .计次循环尾 () k = 取字节集长度 (数据集) 随机变量集 = 取字节集右边 (数据集, 8) ' ------ 分割出随机变量集 数据集 = 取字节集中间 (数据集, 1, k - 8) ' ------ 分割出数据集 ' ----------------------------------(4)开始解密出随机数,和加密部分(4)取反向操作 j = 取字节集长度 (密码集) .计次循环首 (取字节集长度 (随机变量集), i) 随机变量集 [i] = 随机变量集 [i] - 密码集 [j] - 密码叠加量 j = j - 1 .如果真 (j = 0) j = 取字节集长度 (密码集) .如果真结束 .计次循环尾 () 随机数 = 到数值 (到文本 (随机变量集)) 随机数 = 随机数 - 密码叠加量 ' ----------------------------------(5)开始解密数据集,和加密部分(3)取反向操作 j = 取字节集长度 (密码集) .计次循环首 (取字节集长度 (数据集), i) 数据集 [i] = 数据集 [i] - 密码集 [j] - 密码叠加量 - 随机数 j = j - 1 .如果真 (j = 0) j = 取字节集长度 (密码集) .如果真结束 .计次循环尾 () 返回 (0) .如果真结束 返回 (10) .子程序 _打开文件加密_被单击 .局部变量 file1, 整数型, , , 要加密的文件号 .局部变量 file2, 整数型, , , 加密后新建的文件号 .局部变量 code, 字节集, , , 要加密码的密码 .局部变量 exc, 文本型, , "0", 取文件名格式用 .局部变量 文件长度, 长整数型, , , 要加密的文件大小 .局部变量 循环次数, 整数型, , , 加密循环次数 .局部变量 FSO, 对象, , , 用于读取文件属性信息 .局部变量 GetFile, 对象, , , 用于读取文件属性信息 .局部变量 temp, 字节集, , , 临时存放字节集 .局部变量 i, 整数型, , , 提示加密进度用 ' 加密时是以80万计/次读入数据的,每次循环加密后的文件都会多出8字节的随机密匙,所以解密时要以80.008万/次读入数据。 code = 到字节集 (密码编辑框.内容) .如果真 (通用对话框1.打开 ()) file1 = 打开文件 (通用对话框1.文件名, #读写, ) FSO.创建 (“Scripting.FileSystemObject”, ) GetFile = FSO.对象型方法 (“GetFile”, 通用对话框1.文件名) 文件长度 = GetFile.读数值属性 (“Size”, ) exc = 分割文本 (通用对话框1.文件名, “\”, ) file2 = 打开文件 (取当前目录 () + “\CNA+” + exc [取数组成员数 (exc)], #改写, ) 状态条1.置文本 (0, “状态:正在加密..”) 状态条1.置文本 (1, “文件:” + 到文本 (exc [取数组成员数 (exc)])) 循环次数 = 到整数 (文件长度 \ 800000) + 1 .计次循环首 (循环次数, i) temp = 读入字节集 (file1, 800000) CNA数据 (temp, code, 1) 写出字节集 (file2, temp) 状态条1.置文本 (2, “进度:” + 到文本 (取整 (i ÷ 循环次数 × 100)) + “%”) ' -----进度显示以百分比方式显现 .计次循环尾 () 状态条1.置文本 (0, “状态:加密完成”) 关闭文件 (file2) 关闭文件 (file1) .如果真结束 .子程序 _打开文件解密_被单击 .局部变量 file1, 整数型, , , 要加密的文件号 .局部变量 file2, 整数型, , , 加密后新建的文件号 .局部变量 code, 字节集, , , 要加密码的密码 .局部变量 exc, 文本型, , "0", 取文件名格式用 .局部变量 文件长度, 长整数型, , , 要加密的文件大小 .局部变量 循环次数, 整数型, , , 解密循环次数 .局部变量 FSO, 对象, , , 用于读取文件属性信息 .局部变量 GetFile, 对象, , , 用于读取文件属性信息 .局部变量 temp, 字节集, , , 临时存放字节集 .局部变量 i, 整数型, , , 提示加密进度用 ' 注意: 加密时是以80万计/次读入数据的,每次循环加密后的文件都会多出8字节的随机密匙,所以解密时要以80.008万/次读入数据。 code = 到字节集 (密码编辑框.内容) .如果真 (通用对话框1.打开 ()) file1 = 打开文件 (通用对话框1.文件名, #读写, ) FSO.创建 (“Scripting.FileSystemObject”, ) GetFile = FSO.对象型方法 (“GetFile”, 通用对话框1.文件名) 文件长度 = GetFile.读数值属性 (“Size”, ) exc = 分割文本 (通用对话框1.文件名, “\”, ) file2 = 打开文件 (取当前目录 () + “\CNA-” + exc [取数组成员数 (exc)], #改写, ) 状态条1.置文本 (0, “状态:正在解密..”) 状态条1.置文本 (1, “文件:” + 到文本 (exc [取数组成员数 (exc)])) 循环次数 = 到整数 (文件长度 \ 800008) + 1 ' 注意要多出8字节 .计次循环首 (循环次数, i) temp = 读入字节集 (file1, 800008) ' 看文件大小读入多少字节,如果文件非常大,则可以通过移动文件指针方式分段进行加密 CNA数据 (temp, code, ) 写出字节集 (file2, temp) 状态条1.置文本 (2, “进度:” + 到文本 (取整 (i ÷ 循环次数 × 100)) + “%”) ' -----进度显示以百分比方式显现 .计次循环尾 () 状态条1.置文本 (0, “状态:解密完成”) 关闭文件 (file1) 关闭文件 (file2) .如果真结束
运行结果:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接
赞 (0)