学逆向论坛

找回密码
立即注册

只需一步,快速开始

发新帖

2万

积分

41

好友

1168

主题

[Reverse] 渐入佳境wp

发表于 2021-3-26 17:12:23 | 查看: 3634| 回复: 0

相关题目:

♦ 渐入佳境


注册机

#include <stdio.h>
#include <Windows.h>
int main()
{
    char name[6] = { "nmshq" };
    char password[11] = { 0 };

    int val10 = 1;
    for (int k = 0; k < 5; k++)
    {
        password[val10 - 1] = name[k] - (0x1D / (val10 + 0x2) + 0x1E);
        password[val10] = k + password[val10 - 1];
        val10 += 2;
    }

    printf("password:%s\n", password);

    system("pause");
    return 0;
}

程序

004013C5    8D76 00         lea esi,dword ptr ds:[esi]
004013C8    55              push ebp                                              
004013C9    89E5            mov ebp,esp
004013CB    83EC 50         sub esp,0x50
004013CE    56              push esi                                               
004013CF    53              push ebx

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

004013D0    C74             mov value[b-10],0x1

004013DA    8B45 0C         mov eax,name
004013DE    E8 15040000     namestrlen(5) = msvcrt.strlen(name)

004013EC    8B45 10         mov eax,password
004013F0    E8 03040000     passwordstrlen(a) = msvcrt.strlen(password)

004013FB                    mov dword ptr ss:[ebp-0x24],0x1

00401402    837D F8 05      if( namestrlen(5) != 0x5) jnz MessageBoxExA

0040140C    8B45 F8         mov eax,namestrlen(5)
00401411    8D0412          lea eax(10)
00401414    3945 FC         if( passwordstrlen(a) != 0xa) jnz MessageBoxExA

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

00401420    83C0 FD         value[b-4] , namestrlen(5) = add namestrlen(5),-0x3  => 2
0040142D    8D76 00         lea esi,dword ptr ds:[esi]

do{
    mov value[b-C],0x0
    if( value[b-C] > 0x6)
    {
        jmp JIANRUJI.00401500
        lea esi,dword ptr ds:[esi]
    }

    var i;
    add i,value[b-C]
    if(  name[i] > 0x60(a) && name[i] <= 0x7A(z)) jg JIANRUJI.004014F0
    {
        if( password[i] >= 0x41(A) && password[i] <= 0x5A(Z)) 
        {
            movsx eax,password[i + value[b-10] ] 
            movsx edx,password[i + value[b-10] - 0x1]
            if(( eax - edx) == value[b-C])
            {
                movsx ecx,name[ i + value[b-C] ]
                movsx edx,password[i + value[b-10] - 0x1]
                mov value[b-0x34],(ecx - edx)     
                if( value[b-0x34] == (0x1D / (value[b-10] + 0x2) + 0x1E) 
                {
                    add value[b-10],0x2
                    mov passwordstrlen(a) = passwordstrlen(a) + passwordstrlen(a)
                }
                jmp short JIANRUJI.004014F4
            }
        }
    }
--->JIANRUJI.004014F0
    add passwordstrlen(a),-0x19
    value[b-C]++
}while(true)
-----------------------------------------------------------------------------------

004014FC    8D7426 00       lea esi,dword ptr ds:[esi]

00401500    83C4 F8         add esp,-0x8
00401509    8D1400          lea edx,(passwordstrlen(a)-0x9) * 0x2
0040150C    52              push edx
0040150D    8B45 08         mov eax,dword ptr ss:[ebp+0x8]
00401510    50              push eax
00401511    E8 32000000     call JIANRUJI.00401548
00401516    83C4 10         add esp,0x10
00401519    EB 1F           jmp short JIANRUJI.0040153A
0040151B    90              nop

-----------------------------------------------------------MessageBoxExA---------------------------------
0040151C    8D7426 00       lea esi,dword ptr ds:[esi]
00401520    83C4 F4         add esp,-0xC
00401523    6A 04           push 0x4
00401525    6A 10           push 0x10
00401527    6A 00           push 0x0
00401529    68 08134000     push JIANRUJI.00401308
0040152E    8B45 08         mov eax,dword ptr ss:[ebp+0x8]
00401531    50              push eax
00401532    E8 01030000     call JIANRUJI.00401838                                 ; jmp  user32.MessageBoxExA
00401537    83C4 0C         add esp,0xC
0040153A    EB 04           jmp short JIANRUJI.00401540
0040153C    EB 02           jmp short JIANRUJI.00401540
0040153E    89F6            mov esi,esi                                            
00401540    8D65 A8         lea esp,dword ptr ss:[ebp-0x58]
00401543    5B              pop ebx                                                
00401544    5E              pop esi                                                
00401545    C9              leave

00401546    C3              retn
温馨提示:
1.如果您喜欢这篇帖子,请给作者点赞评分,点赞会增加帖子的热度,评分会给作者加学币。(评分不会扣掉您的积分,系统每天都会重置您的评分额度)。
2.回复帖子不仅是对作者的认可,还可以获得学币奖励,请尊重他人的劳动成果,拒绝做伸手党!
3.发广告、灌水回复等违规行为一经发现直接禁言,如果本帖内容涉嫌违规,请点击论坛底部的举报反馈按钮,也可以在【投诉建议】板块发帖举报。
论坛交流群:672619046

小黑屋|手机版|站务邮箱|学逆向论坛 ( 粤ICP备2021023307号 )|网站地图

GMT+8, 2024-11-23 23:31 , Processed in 0.120264 second(s), 36 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表