当前位置:网站首页 > 时间管理与高效工作 > 正文

keil破解到2032年(keil破解时间2020年到期)



11.3.2024学习‘

RC4加密算法详解

0x05 RC4加解密过程

执行以下步骤:

1.创建了两个辅助变量p1和p2并将其设置为0

2.变量p1增加1并且结果是模除以256

3.变量p2在由临时变量p1 (T[p1])确定的位置处增加了数组T中的值。然后,结果被模除以256。

4.数组中位置p1的值与数组中位置p2的值交换。

5.数组中位置p1的值与数组中位置p2的值相加。然后,将结果模除以256并分配给新的辅助变量p3。

6.数组中位置p 3处的值是一个新的密钥流字节。

2. RC4加密算法是一种对称加密算法
对称加密(也叫私钥加密)指加密和解密使用相同密钥的加密算法。就是加密密钥能够从解密密钥中推算出来,同时解密密钥也可以从加密密钥中推算出来。

                       

临时向量k 长度也为256,每个单元也是一个字节。如果密钥的长度是256字节,就直接把密钥的值赋给k,否则,轮转地将密钥的每个字节赋给k;【1】如果输入长度大于等于256个字节,则进行截取【2】如果输入长度小于256个字节,则进行轮转,直到填满,例如输入密钥的是1,2,3,4,5   ,  那么填入的是1,2,3,4,5,1,2,3,4,5,1,2,3,4,5........

3. 用K表对S表进行初始置换

4.X86和X87汇编指令大全(有注释) 

一、数据传输指令

它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 

1. 通用数据传送指令. 

    MOV     传送字或字节. 

    MOVSX   先符号扩展,再传送. 

    MOVZX   先零扩展,再传送. 

    PUSH    把字压入堆栈. 

    POP     把字弹出堆栈. 

    PUSHA   把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈. 

    POPA    把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈. 

    PUSHAD  把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈. 

    POPAD   把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈. 

    BSWAP   交换32位寄存器里字节的顺序 

    XCHG    交换字或字节.(至少有一个操作数为寄存器,段寄存器不可作为操作数) 

    CMPXCHG 比较并交换操作数.(第二个操作数必须为累加器AL/AX/EAX) 

    XADD    先交换再累加.(结果在第一个操作数里) 

    XLAT    字节查表转换.----BX指向一张256字节的表的起点,AL为表的索引值(0-255,即0-FFH);返回AL为查表结果.([BX+AL]->AL) 

2. 输入输出端口传送指令. 

    IN      I/O端口输入. ( 语法: IN   累加器,    {端口号│DX} ) 

    OUT     I/O端口输出. ( 语法: OUT {端口号│DX},累加器 )输入输出端口由立即方式指定时,    其范围是 0-255; 由寄存器 DX 指定时,其范围是    0-65535. 

3. 目的地址传送指令. 

    LEA     装入有效地址.例: LEA DX,string ;把偏移地址存到DX. 

    LDS     传送目标指针,把指针内容装入DS.例: LDS SI,string   ;把段地址:偏移地址存到DS:SI. 

    LES     传送目标指针,把指针内容装入ES.例: LES DI,string   ;把段地址:偏移地址存到ES:DI. 

    LFS     传送目标指针,把指针内容装入FS.例: LFS DI,string   ;把段地址:偏移地址存到FS:DI. 

    LGS     传送目标指针,把指针内容装入GS.例: LGS DI,string   ;把段地址:偏移地址存到GS:DI. 

    LSS     传送目标指针,把指针内容装入SS.例: LSS DI,string   ;把段地址:偏移地址存到SS:DI. 

4. 标志传送指令. 

    LAHF    标志寄存器传送,把标志装入AH. 

    SAHF    标志寄存器传送,把AH内容装入标志寄存器. 

    PUSHF   标志入栈. 

    POPF    标志出栈. 

    PUSHD   32位标志入栈. 

    POPD    32位标志出栈. 

---------- 二、算术运算指令 ---------------------------------------------------- 

    ADD     加法. 

    ADC     带进位加法. 

    INC     加 1. 

    AAA     加法的ASCII码调整. 

    DAA     加法的十进制调整. 

    SUB     减法. 

    SBB     带借位减法. 

    DEC     减 1. 

    NEG     求反(以    0 减之). 

    CMP     比较.(两操作数作减法,仅修改标志位,不回送结果). 

    AAS     减法的ASCII码调整. 

    DAS     减法的十进制调整. 

    MUL     无符号乘法.结果回送AH和AL(字节运算),或DX和AX(字运算), 

    IMUL    整数乘法.结果回送AH和AL(字节运算),或DX和AX(字运算), 

    AAM     乘法的ASCII码调整. 

    DIV     无符号除法.结果回送:商回送AL,余数回送AH, (字节运算);或 商回送AX,余数回送DX, (字运算). 

    IDIV    整数除法.结果回送:商回送AL,余数回送AH, (字节运算);或 商回送AX,余数回送DX, (字运算). 

    AAD     除法的ASCII码调整. 

    CBW     字节转换为字. (把AL中字节的符号扩展到AH中去) 

    CWD     字转换为双字. (把AX中的字的符号扩展到DX中去) 

    CWDE    字转换为双字. (把AX中的字符号扩展到EAX中去) 

    CDQ     双字扩展. (把EAX中的字的符号扩展到EDX中去) 

---------- 三、逻辑运算指令 ---------------------------------------------------- 

    AND     与运算. 

    OR      或运算. 

    XOR     异或运算. 

    NOT     取反. 

    TEST    测试.(两操作数作与运算,仅修改标志位,不回送结果). 

    SHL     逻辑左移. 

    SAL     算术左移.(=SHL) 

    SHR     逻辑右移. 

    SAR     算术右移.(=SHR) 

    ROL     循环左移. 

    ROR     循环右移. 

    RCL     通过进位的循环左移. 

    RCR     通过进位的循环右移. 

              以上八种移位指令,其移位次数可达255次. 

              移位一次时, 可直接用操作码. 如 SHL AX,1. 

              移位>1次时, 则由寄存器CL给出移位次数. 

              如 MOV CL,04   SHL AX,CL 

---------- 四、串指令 ---------------------------------------------------------- 

              DS:SI 源串段寄存器 :源串变址. 

              ES:DI 目标串段寄存器:目标串变址. 

              CX 重复次数计数器. 

              AL/AX 扫描值. 

              D标志   0表示重复操作中SI和DI应自动增量; 1表示应自动减量. 

              Z标志   用来控制扫描或比较操作的结束. 

    MOVS    串传送.( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. ) 

    CMPS    串比较.( CMPSB 比较字符. CMPSW 比较字. ) 

    SCAS    串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位. 

    LODS    装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB 传送字符. LODSW 传送字.    LODSD 传送双字. ) 

    STOS    保存串.是LODS的逆过程. 

    REP         当CX/ECX<>0时重复. 

    REPE/REPZ   当ZF=1或比较结果相等,且CX/ECX<>0时重复. 

    REPNE/REPNZ 当ZF=0或比较结果不相等,且CX/ECX<>0时重复. 

    REPC        当CF=1且CX/ECX<>0时重复. 

    REPNC       当CF=0且CX/ECX<>0时重复. 

---------- 五、程序转移指令 ---------------------------------------------------- 

1. 无条件转移指令 (长转移) 

    JMP         无条件转移指令 

    CALL        过程调用 

    RET/RETF    过程返回. 

2. 条件转移指令   (短转移,-128到+127的距离内)( 当且仅当(SF XOR OF)=1时,OP1<OP2 ) 

    JA/JNBE     不小于或不等于时转移. 

    JAE/JNB     大于或等于转移. 

    JB/JNAE     小于转移. 

    JBE/JNA     小于或等于转移. 

        以上四条,测试无符号整数运算的结果(标志C和Z). 

    JG/JNLE     大于转移. 

    JGE/JNL     大于或等于转移. 

    JL/JNGE     小于转移. 

    JLE/JNG     小于或等于转移. 

        以上四条,测试带符号整数运算的结果(标志S,O和Z). 

    JE/JZ       等于转移. 

    JNE/JNZ     不等于时转移. 

    JC          有进位时转移. 

    JNC         无进位时转移. 

    JNO         不溢出时转移. 

    JNP/JPO     奇偶性为奇数时转移. 

    JNS         符号位为 "0" 时转移. 

    JO          溢出转移. 

    JP/JPE      奇偶性为偶数时转移. 

    JS          符号位为 "1" 时转移. 

3. 循环控制指令(短转移) 

    LOOP            CX不为零时循环. 

    LOOPE/LOOPZ     CX不为零且标志Z=1时循环. 

    LOOPNE/LOOPNZ   CX不为零且标志Z=0时循环. 

    JCXZ            CX为零时转移. 

    JECXZ           ECX为零时转移. 

4. 中断指令 

    INT         中断指令 

    INTO        溢出中断 

    IRET        中断返回 

5. 处理器控制指令 

    HLT         处理器暂停,  直到出现中断或复位信号才继续. 

    WAIT        当芯片引线TEST为高电平时使CPU进入等待状态. 

    ESC         转换到外处理器. 

    LOCK        封

------------------------------- 

    DW          定义字(2字节). 

    PROC        定义过程. 

    ENDP        过程结束. 

    SEGMENT     定义段. 

    ASSUME      建立段寄存器寻址. 

    ENDS        段结束. 

    END         程序结束. 

---------- 七、处理机控制指令:标志处理指令 ------------------------------------ 

    CLC     进位位置0指令 

    CMC     进位位求反指令 

    STC     进位位置为1指令 

    CLD     方向标志置1指令 

    STD     方向标志位置1指令 

    CLI     中断标志置0指令 

    STI     中断标志置1指令 

    NOP     无操作 

    HLT     停机 

    WAIT    等待 

    ESC     换码 

    LOCK    封锁 

4.培训:

1> 二进制符号位

0x66u u的意思是无符号整型,ascii一般有七位,但二进制转过去的时候有八位,第一位一般是

作为符号位,如果变量是unsigned,则它是无符号位的,则不考虑第一位,用来解一些加密的时候用

2> buf 缓冲区

3>将二进制化为六个为一组,不足六位用0补齐,转成十进制,对应base64编码来看,结果不是4的倍数需要在结尾补充等号(意思:比如搞出sa这些,把它们四个四个划分,如果最后不是4的倍数则补充等号)

4>与运算:只有1和1出1,其他的都出0

FC AND 只取前面六位 得

<<表示向左移两位

  1. 美国药典 脱壳显示不对,把它放在winhex(查看16进制工具)里,将usp改为upx

错误如下

Ida里变量改名:点击n

放到脚本里,脚本如上

到此这篇keil激活成功教程到2032年(keil激活成功教程时间2020年到期)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 三星c7000(三星c7000上市时间)2025-05-06 12:09:04
  • 三星c7000上市时间(三星c7000什么型号)2025-05-06 12:09:04
  • 时间指令(泰拉瑞亚时间指令)2025-05-06 12:09:04
  • 我的世界设置时间指令黎明(我的世界黎明的指令)2025-05-06 12:09:04
  • aw是什么工作(aw是什么意思的缩写)2025-05-06 12:09:04
  • impdp导入命令参数详解(impdp导入很长时间没有反应)2025-05-06 12:09:04
  • ad52117功率(ad712最佳工作电压)2025-05-06 12:09:04
  • impdp导入dump文件(impdp导入很长时间没有反应)2025-05-06 12:09:04
  • w25q128jvsiq电压(ws2812工作电压)2025-05-06 12:09:04
  • k8s 发布时间(k8s发布时间)2025-05-06 12:09:04
  • 全屏图片