易语言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)
.如果真结束
运行结果:
总结
以上是 易语言CNA算法实现快速加密解密文件的代码 的全部内容, 来源链接: utcz.com/z/344460.html