SM4加解密易语言源码

SM4加解密易语言源码

.版本 2 .程序集 程序集3 .子程序 位运算_左移_长整数型_ASM, 长整数型 .参数 数值, 长整数型 .参数 位数, 整数型 ' 置入代码 (#shl64) 置入代码 ({ 139, 69, 8, 139, 85, 12, 139, 77, 16, 131, 249, 64, 124, 8, 49, 192, 49, 210, 201, 194, 12, 0, 131, 249, 32, 124, 23, 116, 13, 131, 233, 32, 211, 224, 137, 194, 49, 192, 201, 194, 12, 0, 137, 194, 49, 192, 201, 194, 12, 0, 15, 165, 194, 211, 224, 201, 194, 12, 0 }) 返回 (0) .子程序 位运算_右移_长整数型_ASM, 长整数型 .参数 数值, 长整数型 .参数 位数, 整数型 ' 置入代码 (#shr64) 置入代码 ({ 139, 69, 8, 139, 85, 12, 139, 77, 16, 131, 249, 64, 124, 8, 49, 192, 49, 210, 201, 194, 12, 0, 131, 249, 32, 124, 23, 116, 13, 131, 233, 32, 137, 208, 211, 232, 49, 210, 201, 194, 12, 0, 137, 208, 49, 210, 201, 194, 12, 0, 15, 173, 208, 211, 234, 201, 194, 12, 0 }) 返回 (0) .子程序 取变量数据地址_ASM, 整数型 .参数 变量, 通用型, 参考 .参数 数据类型, 整数型, 可空 置入代码 ({ 139, 69, 8, 131, 125, 12, 9, 15, 142, 15, 0, 0, 0, 139, 0, 131, 125, 12, 11, 15, 133, 3, 0, 0, 0, 131, 192, 8, 201, 194, 12, 0 }) ' mov eax, dword ptr [ebp+08h] ' cmp dword ptr [ebp+0Ch], 09h ' jng 009F968Ch ' mov eax, dword ptr [eax] ' cmp dword ptr [ebp+0Ch], 0Bh ' jne 009F968Ch ' add eax, 08h ' leave ' retn 000Ch 返回 (0) .子程序 进制_字节集到十六进制_ASM, 文本型, , 返回把字节集数据转换为16进制数据文本,每2个字符为1字节数据 .参数 字节集数据, 字节集, , 待转换字节集数据. .参数 分隔符号, 文本型, 可空, 分隔符的作用就是 FF分隔FF分隔FF 空=""=不分隔. .参数 保留参数, 整数型, 可空, 此参数不需要使用. .局部变量 十六进制, 文本型, , , 保存转换后的十六进制.若空,以返回值返回结果 保留参数 = 取字节集长度 (字节集数据) .如果真 (保留参数 > 0) 十六进制 = 取重复文本 (保留参数, “00” + 分隔符号) 保留参数 = 取变量数据地址_ASM (十六进制, #文本型) ' 0040357E 837D 10 00 cmp dword ptr [ebp+10], 0 ; 分隔为空? ' 00403582 74 17 je short 0040359B ; 为空 跳 ' 00403584 FF4D 10 dec dword ptr [ebp+10] ; 分隔长度=0 ' 00403589 8B45 0C mov eax, dword ptr [ebp+C] ; EAX=参数2 ' 0040358C 85C0 test eax, eax ' 0040358E 74 0D je short 0040359D ; 空参 跳 ' 00403590 8B00 mov eax, dword ptr [eax] ; EAX=分隔符 ' 00403592 8038 00 cmp byte ptr [eax], 0 ' 00403595 74 06 je short 0040359D ; 终止 跳 ' 00403597 FF45 10 inc dword ptr [ebp+10] ; 递增长度 ' 0040359A 40 inc eax ; 递增地址 ' 0040359B ^ EB F5 jmp short 00403592 ; 继续循环 ' 0040359D 90 nop ' 0040359E 51 push ecx ; 备份ECX ' 0040359F 52 push edx ; 备份EDX ' 004035A0 53 push ebx ; 备份EBX ' 004035A1 56 push esi ; 备份ESI ' 004035A2 57 push edi ; 备份EDI ' 004035A3 8B45 08 mov eax, dword ptr [ebp+8] ; EAX=参数1 ' 004035A6 8B00 mov eax, dword ptr [eax] ; EAX=字节集首 ' 004035A8 8B48 04 mov ecx, dword ptr [eax+4] ; ECX=字节集长 ' 004035AB 83C0 08 add eax, 8 ; EAX=字节集指针 ' 004035AE 8BF0 mov esi, eax ; EBX=字节集指针 ' 004035B0 8B7D 14 mov edi, dword ptr [ebp+14] ; EDI=十六文本 ' 004035B3 33C0 xor eax, eax ; EAX=0 ' 004035B5 BB 10000000 mov ebx, 10 ; EBX=16除数 ' 004035BA 90 nop ' 004035BB 85C9 test ecx, ecx ; 长度=0? ' 004035BD 74 23 je short 004035E2 ; 等于0 跳 ' 004035BF 49 dec ecx ; 递减长度 ' 004035C0 8A06 mov al, byte ptr [esi] ; 取1字节 ' 004035C2 33D2 xor edx, edx ; EDX=0 余 ' 004035C4 F7F3 div ebx ; 除以16 ' 004035C6 83F8 0A cmp eax, 0A ; 商>10 ' 004035C9 72 03 jb short 004035CE ; 小于 跳 ' 004035CB 83C0 07 add eax, 7 ; 英文 + 55 ' 004035CE 0007 add byte ptr [edi], al ; 英文 + 48 ' 004035D0 47 inc edi ; 递增文本 ' 004035D1 83FA 0A cmp edx, 0A ; 余>10 ' 004035D4 72 03 jb short 004035D9 ; 小于 跳 ' 004035D6 83C2 07 add edx, 7 ; 英文 + 55 ' 004035D9 0017 add byte ptr [edi], dl ; 英文 + 48 ' 004035DB 47 inc edi ; 递增文本 ' 004035DC 037D 10 add edi, dword ptr [ebp+10] ; 跳过分隔符 ' 004035DF 46 inc esi ; 递增字节集 ' 004035E0 ^ EB D9 jmp short 004035BB ; 继续循环 ' 004035E2 90 nop ' 004035E3 397D 14 cmp dword ptr [ebp+14], edi ; 处理过数据 ' 004035E6 74 01 je short 004035E9 ; 未处 跳 ' 00401019 2B7D 10 sub edi, dword ptr [ebp+10] ; 递减文本 ' 004035E9 880F mov byte ptr [edi], cl ; 截断字符 ' 004035EB 5F pop edi ; 恢复EDI ' 004035EC 5E pop esi ; 恢复ESI ' 004035ED 5B pop ebx ; 恢复EBX ' 004035EE 5A pop edx ; 恢复EDX ' 004035EF 59 pop ecx ; 恢复ECX ' 83 7D 10 00 74 17 FF 4D 10 8B 45 0C 85 C0 74 0D 8B 00 80 38 00 74 06 FF 45 10 40 EB F5 90 51 52 53 56 ' 57 8B 45 08 8B 00 8B 48 04 83 C0 08 8B F0 8B 7D 14 33 C0 BB 10 00 00 00 90 85 C9 74 23 49 8A 06 ' 33 D2 F7 F3 83 F8 0A 72 03 83 C0 07 00 07 47 83 FA 0A 72 03 83 C2 07 00 17 47 03 7D 10 46 EB D9 ' 90 39 7D 14 74 01 2B 7D 10 88 0F 5F 5E 5B 5A 59 置入代码 ({ 131, 125, 16, 0, 116, 23, 255, 77, 16, 139, 69, 12, 133, 192, 116, 13, 139, 0, 128, 56, 0, 116, 6, 255, 69, 16, 64, 235, 245, 144, 81, 82, 83, 86, 87, 139, 69, 8, 139, 0, 139, 72, 4, 131, 192, 8, 139, 240, 139, 125, 20, 51, 192, 187, 16, 0, 0, 0, 144, 133, 201, 116, 35, 73, 138, 6, 51, 210, 247, 243, 131, 248, 10, 114, 3, 131, 192, 7, 0, 7, 71, 131, 250, 10, 114, 3, 131, 194, 7, 0, 23, 71, 3, 125, 16, 70, 235, 217, 144, 57, 125, 20, 116, 1, 43, 125, 16, 136, 15, 95, 94, 91, 90, 89 }) .如果真结束 返回 (十六进制) .子程序 进制_十六进制到字节集_ASM, 字节集, , 返回把指定16进制文本数据还原为字节集.每个字节由2个字符组成 .参数 十六进制文本, 文本型, , 例如 {FF,0A,DA} 或者 FF,0A,DA 或者 FF0ADA 等等 .参数 保留参数, 整数型, 可空, 此参数不需要使用. .局部变量 字节集, 字节集 字节集 = 到字节集 (十六进制文本) 保留参数 = 取变量数据地址_ASM (字节集, #字节集型) ' 00401226 50 push eax ; 备份寄存器 ' 00401227 51 push ecx ' 00401228 52 push edx ' 00401229 53 push ebx ' 0040122A 56 push esi ' 0040122B 57 push edi ; 备份寄存器 ' 0040122C 33C0 xor eax, eax ' 0040122E 33C9 xor ecx, ecx ' 00401230 33D2 xor edx, edx ' 00401232 33DB xor ebx, ebx ' 00401234 8B75 08 mov esi, dword ptr [ebp+8] ; ESI=十六文本指针 ' 00401237 8B7D 0C mov edi, dword ptr [ebp+C] ; EDI=字节集指针 ' 0040123A 85F6 test esi, esi ; 空文本? ' 0040123C 74 04 je short 00401242 ; 空 跳 ' 0040123E 8B36 mov esi, dword ptr [esi] ' 00401240 85F6 test esi, esi ; 空文本? ' 00401242 74 53 je short 00401297 ; 空 跳 ' 00401244 90 nop ' 00401245 8A1E mov bl, byte ptr [esi] ; 读取1字符 ' 00401247 46 inc esi ; 递增进制地址 ' 00401248 80FB 30 cmp bl, 30 ' 0040124B 72 3D jb short 0040128A ; 非法字 跳 ' 0040124D 80FB 39 cmp bl, 39 ' 00401250 77 05 ja short 00401257 ; 大于"9"跳 ' 00401252 80EB 30 sub bl, 30 ; 0-9 ' 00401255 EB 1D jmp short 00401274 ; 数字区 跳 ' 00401257 80FB 41 cmp bl, 41 ' 0040125A 72 2E jb short 0040128A ; 非法字 跳 ' 0040125C 80FB 46 cmp bl, 46 ' 0040125F 77 05 ja short 00401266 ; 大于"F"跳 ' 00401261 80EB 37 sub bl, 37 ; A-F ' 00401264 EB 0E jmp short 00401274 ; 字母区 跳 ' 00401266 80FB 61 cmp bl, 61 ' 00401269 72 1F jb short 0040128A ; 非法字 跳 ' 0040126B 80FB 66 cmp bl, 66 ; 非法字 跳 ' 0040126E 77 1A ja short 0040128A ; a-f ' 00401270 80EB 57 sub bl, 57 ' 00401273 90 nop ' 00401274 85C0 test eax, eax ; 有无高位? 正常进制处理 ' 00401276 75 05 jnz short 0040127D ; 有高位跳 ' 00401278 40 inc eax ; 置有高位 ' 00401279 8BD3 mov edx, ebx ; 保存高位 ' 0040127B ^ EB C8 jmp short 00401245 ; 继续循环 ' 0040127D 48 dec eax ; 置无高位 ' 0040127E 41 inc ecx ; 递增长度 ' 0040127F C1E2 04 shl edx, 4 ; 左移高位 ' 00401282 09DA or edx, ebx ; 合并字节 ' 00401284 8817 mov byte ptr [edi], dl ; 保存字节 ' 00401286 47 inc edi ; 递增写入 ' 00401287 ^ EB BC jmp short 00401245 ; 继续循环 ' 00401289 90 nop ' 0040128A 85C0 test eax, eax ; 有无未存? 非法字符处理 ' 0040128C 74 05 je short 00401293 ; 无未存跳 ' 0040128E 48 dec eax ; 置无未存 ' 0040128F 41 inc ecx ; 递增长度 ' 00401290 8817 mov byte ptr [edi], dl ; 保存字节 ' 00401292 47 inc edi ; 递增写入 ' 00401293 85DB test ebx, ebx ; 是否 {0}? ' 00401295 ^ 75 AE jnz short 00401245 ; 继续循环 ' 00401297 894D 0C mov dword ptr [ebp+C], ecx ; 参数2=长度 ' 0040129A 5F pop edi ; 恢复寄存器 ' 0040129B 5E pop esi ' 0040129C 5B pop ebx ' 0040129D 5A pop edx ' 0040129E 59 pop ecx ' 0040129F 58 pop eax ; 恢复寄存器 ' 50 51 52 53 56 57 33 C0 33 C9 33 D2 33 DB 8B 75 08 8B 7D 0C 85 F6 74 04 8B 36 85 F6 74 53 90 8A ' 1E 46 80 FB 30 72 3D 80 FB 39 77 05 80 EB 30 EB 1D 80 FB 41 72 2E 80 FB 46 77 05 80 EB 37 EB 0E ' 80 FB 61 72 1F 80 FB 66 77 1A 80 EB 57 90 85 C0 75 05 40 8B D3 EB C8 48 41 C1 E2 04 09 DA 88 17 ' 47 EB BC 90 85 C0 74 05 48 41 88 17 47 85 DB 75 AE 89 4D 0C 5F 5E 5B 5A 59 58 置入代码 ({ 80, 81, 82, 83, 86, 87, 51, 192, 51, 201, 51, 210, 51, 219, 139, 117, 8, 139, 125, 12, 133, 246, 116, 4, 139, 54, 133, 246, 116, 83, 144, 138, 30, 70, 128, 251, 48, 114, 61, 128, 251, 57, 119, 5, 128, 235, 48, 235, 29, 128, 251, 65, 114, 46, 128, 251, 70, 119, 5, 128, 235, 55, 235, 14, 128, 251, 97, 114, 31, 128, 251, 102, 119, 26, 128, 235, 87, 144, 133, 192, 117, 5, 64, 139, 211, 235, 200, 72, 65, 193, 226, 4, 9, 218, 136, 23, 71, 235, 188, 144, 133, 192, 116, 5, 72, 65, 136, 23, 71, 133, 219, 117, 174, 137, 77, 12, 95, 94, 91, 90, 89, 88 }) 返回 (取字节集左边 (字节集, 保留参数)) .子程序 位运算_位与_长整数_ASM, 长整数型 .参数 val1, 长整数型 .参数 val2, 长整数型 置入代码 ({ 139, 69, 8, 35, 69, 16, 139, 85, 12, 35, 85, 20, 93, 194, 16, 0 }) 返回 (0) .子程序 位运算_位或_长整数_ASM, 长整数型 .参数 val1, 长整数型 .参数 val2, 长整数型 置入代码 ({ 139, 69, 8, 11, 69, 16, 139, 85, 12, 11, 85, 20, 93, 194, 16, 0 }) 返回 (0) .子程序 位运算_位异或_长整数_ASM, 长整数型 .参数 val1, 长整数型 .参数 val2, 长整数型 置入代码 ({ 139, 69, 8, 51, 69, 16, 139, 85, 12, 51, 85, 20, 93, 194, 16, 0 }) 返回 (0)
相关文件下载地址
©下载资源版权归作者所有;本站所有资源均来源于网络,仅供学习使用,请支持正版!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注