当前位置: 首页 > news >正文

科协科普网站建设网页建设与网站设计

科协科普网站建设,网页建设与网站设计,深圳专业做网站技术,厦门网站流量优化价格环境#xff1a; Windows xp sp3 工具 exeinfope OllyDBG 查壳 用exeinfope查壳#xff0c;发现是没有壳的。 测试 可以看出是从红色框框里面的内容判断serial是否有效 OD载入#xff0c;字符串搜索可以得到#xff1a; 004011EC . 55 pus…环境 Windows xp sp3 工具 exeinfope OllyDBG 查壳 用exeinfope查壳发现是没有壳的。 测试 可以看出是从红色框框里面的内容判断serial是否有效 OD载入字符串搜索可以得到 004011EC . 55 push ebp 004011ED . 8BEC mov ebp,esp 004011EF . 83C4 FC add esp,-0x4 004011F2 . 8B45 0C mov eax,dword ptr ss:[ebp0xC] 004011F5 . 83F8 10 cmp eax,0x10 ; Switch (cases 1..111) 004011F8 . 75 0D jnz XChafe_2.00401207 004011FA . 6A 00 push 0x0 ; /ExitCode 0; Case 10 (WM_CLOSE) of switch 004011F5 004011FC . E8 6B020000 call jmp.USER32.PostQuitMessage ; \PostQuitMessage 00401201 . 33C0 xor eax,eax 00401203 . C9 leave 00401204 . C2 1000 retn 0x10 00401207 83F8 0F cmp eax,0xF 0040120A . 75 0E jnz XChafe_2.0040121A 0040120C . 8B45 08 mov eax,dword ptr ss:[ebp0x8] ; Case F (WM_PAINT) of switch 004011F5 0040120F . E8 18010000 call Chafe_2.0040132C 00401214 . 33C0 xor eax,eax 00401216 . C9 leave 00401217 . C2 1000 retn 0x10 0040121A 83F8 01 cmp eax,0x1 0040121D . 75 06 jnz XChafe_2.00401225 0040121F . 33C0 xor eax,eax ; Case 1 (WM_CREATE) of switch 004011F5 00401221 . C9 leave 00401222 . C2 1000 retn 0x10 00401225 3D 11010000 cmp eax,0x111 0040122A . 0F85 E7000000 jnz Chafe_2.00401317 00401230 . 8B45 14 mov eax,dword ptr ss:[ebp0x14] ; Case 111 (WM_COMMAND) of switch 004011F5 00401233 . 3B05 60314000 cmp eax,dword ptr ds:[0x403160] 00401239 . 75 1A jnz XChafe_2.00401255 0040123B . 6A 00 push 0x0 ; /Style MB_OK|MB_APPLMODAL 0040123D . 68 96304000 push Chafe_2.00403096 ; |Title About TEXme v2.0 00401242 . 68 A7304000 push Chafe_2.004030A7 ; |Text Small crack-me program written by Chafe/TEX99RULES: Find a serial that matches your name or write a keygenerator. NO PATCHES IS ALLOWED!Released 19/7-99 00401247 . FF75 08 push dword ptr ss:[ebp0x8] ; |hOwner 0040124A . E8 17020000 call jmp.USER32.MessageBoxA ; \MessageBoxA 0040124F . 33C0 xor eax,eax 00401251 . C9 leave 00401252 . C2 1000 retn 0x10 00401255 3B05 58314000 cmp eax,dword ptr ds:[0x403158] 0040125B . 74 0C je XChafe_2.00401269 0040125D . 3B05 54314000 cmp eax,dword ptr ds:[0x403154] 00401263 . 0F85 AE000000 jnz Chafe_2.00401317 00401269 C705 D9124000 544mov dword ptr ds:[0x4012D9],0x584554 00401273 . 6A 00 push 0x0 ; /IsSigned FALSE 00401275 . 8D45 FC lea eax,dword ptr ss:[ebp-0x4] ; | 00401278 . 50 push eax ; |pSuccess 00401279 . 6A 64 push 0x64 ; |ControlID 64 (100.) 0040127B . FF35 50314000 push dword ptr ds:[0x403150] ; |hWnd NULL 00401281 . E8 BC010000 call jmp.USER32.GetDlgItemInt ; \GetDlgItemInt 00401286 . 837D FC 00 cmp dword ptr ss:[ebp-0x4],0x0 0040128A . 74 5F je XChafe_2.004012EB 0040128C . 50 push eax 0040128D . 6A 14 push 0x14 ; /Count 14 (20.) 0040128F . 68 6C314000 push Chafe_2.0040316C ; |Buffer Chafe_2.0040316C 00401294 . FF35 54314000 push dword ptr ds:[0x403154] ; |hWnd NULL 0040129A . E8 AF010000 call jmp.USER32.GetWindowTextA ; \GetWindowTextA 0040129F . 85C0 test eax,eax 004012A1 . 74 48 je XChafe_2.004012EB 004012A3 . A1 0B304000 mov eax,dword ptr ds:[0x40300B] ; 这里初始化 004012A8 . BB 6C314000 mov ebx,Chafe_2.0040316C 004012AD 0303 add eax,dword ptr ds:[ebx] ; 这里是将name的内容加进去具体怎么加可以单步跟踪看一看 004012AF . 43 inc ebx 004012B0 . 81FB 7C314000 cmp ebx,Chafe_2.0040317C ; 判断是否到达这个位置 004012B6 .^ 75 F5 jnz XChafe_2.004012AD 004012B8 . 5B pop ebx 004012B9 . 03C3 add eax,ebx ; 加上serial的值 004012BB . 3105 D9124000 xor dword ptr ds:[0x4012D9],eax 004012C1 . C1E8 10 shr eax,0x10 004012C4 . 66:2905 D9124000 sub word ptr ds:[0x4012D9],ax 004012CB . BE EC114000 mov esi,Chafe_2.004011EC 004012D0 . B9 3E000000 mov ecx,0x3E 004012D5 . 33DB xor ebx,ebx 004012D7 . EB 04 jmp XChafe_2.004012DD 004012D9 54 push esp 004012DA 45 db 45 ; CHAR E 004012DB 58 db 58 ; CHAR X 004012DC 00 db 00 004012DD AD lods dword ptr ds:[esi] ; 从4012CB可以看出esi的内容 004012DE . 33D8 xor ebx,eax 004012E0 . 49 dec ecx 004012E1 .^ 75 FA jnz XChafe_2.004012DD 004012E3 . 81FB FBCFFCAF cmp ebx,0xAFFCCFFB ; 这个比较要相等才行 004012E9 .^ 74 EE je XChafe_2.004012D9 004012EB 68 59304000 push Chafe_2.00403059 ; /Text Your serial is not valid. 004012F0 . FF35 5C314000 push dword ptr ds:[0x40315C] ; |hWnd NULL 004012F6 . E8 7D010000 call jmp.USER32.SetWindowTextA ; \SetWindowTextA 004012FB . 33C0 xor eax,eax 004012FD . C9 leave 004012FE . C2 1000 retn 0x10 00401301 . 68 73 30 40 00 ascii hs0,0 00401306 . FF35 5C314000 push dword ptr ds:[0x40315C] ; |hWnd NULL 0040130C . E8 67010000 call jmp.USER32.SetWindowTextA ; \SetWindowTextA 00401311 . 33C0 xor eax,eax 00401313 . C9 leave 00401314 . C2 1000 retn 0x10 一下子可以找到是[004012EB]这个位置使得显示serial的内容不正确而显示serial正确的内容却没有在下面的的函数显示出来而[00401301]这个位置却是在显示 00401301 . 68 73 30 40 00 ascii hs0,0 可以在内存窗口跟踪[00403073]看到了这个 00403073 59 45 53 21 20 59 6F 75 YES! You 0040307B 20 66 6F 75 6E 64 20 79 found y 00403083 6F 75 72 20 73 65 72 69 our seri 0040308B 61 6C 21 21 al!!可以看出只要跳转跳到[00401301]就可以显示正确内容。 往上查看后却发现并没有一个跳转是跳到[00401301]的而且[004012D9]-[0012DC]是一些数据。 细心一点可以看到 004012C4 . 66:2905 D9124000 sub word ptr ds:[0x4012D9],ax 这里会更改[004012D9]的内容于是可以猜测 在执行[004012C4]后[004012D9]的内容发生改变并在[004012D9]处出现一个jmp并且跳向[00401301] 分析前面指令的内容可以知道 1.程序将eax初始化为特定的值后将输入的name加到eax中 2.然后将eax的值加上serial的值,结果保存在eax 3.将eax的值和[004012D9]位置的值进行异或运算结果保存在[00401D9] 4.最后再用[004012D9]的值减去eax右移16位后的值。 如果忽略了[004012E1]处的判断会发现即使[004012D9]处的指令是跳到[00401301]处也没用因为[004012D9]的指令并不会执行。所以要使得ebx的值为0xAFFCCFFB而这个值是将[004011EC]处开始每4个字节的内容赋值到eax不断的与ebx异或得出的。 要注意到的是输入的内容会改变[004012D9]的内容而[004012D9]的内容会影响后面异或的结果。所以可以 根据异或的结果即0xAFFCCFFB来推算出[004012D9]的内容即第4步的结果又根据得出的内容推算出serial的值。 我自己算出[004012D9]的内容应该为 0x585426EB 恰好 EB 26 是 jmp X00401301 所以可以容易得出注册机 char s[50];unsigned int *temp;unsigned int sum 0x58455443;unsigned int result 0x585426EB;unsigned int x 0x584554;unsigned int bian,k;memset(s,0,sizeof(s));scanf(%s,s);//求第一步结果即将name加到eax for(int i0;i16;i){temp (unsigned int*)s[i];sum *temp;}//求第二、三步结果 for(unsigned int i0;i0xFF;i){unsigned int j;bian 0x5800; //注意到[004012C4]有个sub而sub的其中一个值是(sumseria)16的值k 0;bian bian | i;k bian result ; //算出异或后的结果k ^ x; //算出异或前的结果j k 16;if(j bian) //这里要保证加上的bian的值和(sumseria)16的值相同{printf(serial: %u,k-sum);} } 最后会发现最后减掉的值为0x580C测试了多组数据都是这个值。其中的原理没找到。
http://www.zqtcl.cn/news/913835/

相关文章:

  • 昆明做网站建设找谁郑州网站制作的公司哪家好
  • 天津seo网站推广如何做医美机构网站观察分析
  • 东莞网站到首页排名网站建设与设计主要是干什么的
  • 自己做网站要花钱吗个人网站可以做资讯吗
  • 做vr效果图的网站做小程序的公司有哪些比较好
  • 物流建设网站总结制作壁纸的软件
  • 自己电脑做主机怎么做网站培训公司排名
  • 网站seo优化排名qq空间wordpress搬家
  • 做二手元器件那个网站查价格元气森林网络营销策略分析
  • 优质网站建设是哪家17网站一起做网店不发货
  • 建设企业网银如何对账seo优化推广工程师
  • 广州制作外贸网站小说网站制作公司
  • 东莞南城网站建设价格注册深圳公司有什么好处
  • 做网站图片大小建个人网站要多少钱
  • 北京免费建网站seo网站关键词
  • 南宁网站制作公司dede网站建站教程
  • 辽宁省建设工程招标协会网站自建网站主题及策划
  • 石材做网站google建网站
  • 装配式建筑信息平台无忧seo博客
  • 做淘客网站用备案网络推广预算方案
  • 网站建设需不需要招标好网站欣赏
  • 怎样创建网站的代码此网站域名即将过期
  • 网页转向网站jquery图片效果网站
  • 山东定制网页建站wordpress是是什么技术
  • 无锡免费网站制作手游网页版
  • 东莞 网站建设 定制水寻找常州微信网站建设
  • 在门户网站做推广网站开发需要20万
  • 网站做电商销售需要注册吗上海的公司地址
  • 给网站做选题计算机网络技术电商网站建设与运营方向
  • 网站如何做熊掌号并绑定wordpress pdf