【文章标题】: 超级电视 5.2.3算法分析
【文章作者】: 坚持到底
【软件名称】: 超级电视 5.2.3
【软件大小】: 894KB
【下载地址】: http://www.newhua.com/soft/44942.htm
【加壳方式】: 无
【保护方式】: 注册码
【编写语言】: VB
【使用工具】: VBExplorer,OD,PEID
【操作平台】: XPSP2
【软件介绍】: 超级电视可接收各地精彩电视节目和广播电台,软件
【作者声明】: 只是感兴趣,没有其他目的。失误之处敬请诸位大侠赐教!
--------------------------------------------------------------------------------
【详细过程】
通过VBExplorer找到 立即注册 的按钮地址 下断
软件生成随机数存在根目录下Iotmrd.sys 文件中 随机数记为A
/////////////////////////////////////////////////////////////////////////////////////////////////
生成注册码的过程
/////////////////////////////////////////////////////////////////////////////////////////////////
0045B4BF 90 nop
0045B4C0 55 push ebp
0045B4C1 8BEC mov ebp,esp
0045B4C3 83EC 0C sub esp,0C
0045B4C6 68 A6134000 push <jmp.&MSVBVM50.__vbaExceptHandler>
0045B4CB 64:A1 00000000 mov eax,dword ptr fs:[0]
0045B4D1 50 push eax
0045B4D2 64:8925 00000000 mov dword ptr fs:[0],esp
0045B4D9 81EC EC000000 sub esp,0EC
0045B4DF 53 push ebx
0045B4E0 8B5D 08 mov ebx,dword ptr ss:[ebp+8]
0045B4E3 8BC3 mov eax,ebx
0045B4E5 56 push esi
0045B4E6 83E3 FE and ebx,FFFFFFFE
0045B4E9 57 push edi
0045B4EA 8965 F4 mov dword ptr ss:[ebp-C],esp
0045B4ED 83E0 01 and eax,1
0045B4F0 8B33 mov esi,dword ptr ds:[ebx]
0045B4F2 C745 F8 10134000 mov dword ptr ss:[ebp-8],supernet.00401310
0045B4F9 53 push ebx
0045B4FA 8945 FC mov dword ptr ss:[ebp-4],eax
0045B4FD 895D 08 mov dword ptr ss:[ebp+8],ebx
0045B500 89B5 10FFFFFF mov dword ptr ss:[ebp-F0],esi
0045B506 FF56 04 call dword ptr ds:[esi+4]
0045B509 8BB6 0C030000 mov esi,dword ptr ds:[esi+30C]
0045B50F 33FF xor edi,edi
0045B511 53 push ebx
0045B512 897D E0 mov dword ptr ss:[ebp-20],edi
0045B515 897D DC mov dword ptr ss:[ebp-24],edi
0045B518 897D D8 mov dword ptr ss:[ebp-28],edi
0045B51B 897D D4 mov dword ptr ss:[ebp-2C],edi
0045B51E 897D D0 mov dword ptr ss:[ebp-30],edi
0045B521 897D CC mov dword ptr ss:[ebp-34],edi
0045B524 897D C8 mov dword ptr ss:[ebp-38],edi
0045B527 897D C4 mov dword ptr ss:[ebp-3C],edi
0045B52A 897D B4 mov dword ptr ss:[ebp-4C],edi
0045B52D 897D A4 mov dword ptr ss:[ebp-5C],edi
0045B530 897D 94 mov dword ptr ss:[ebp-6C],edi
0045B533 897D 84 mov dword ptr ss:[ebp-7C],edi
0045B536 89BD 74FFFFFF mov dword ptr ss:[ebp-8C],edi
0045B53C 89BD 64FFFFFF mov dword ptr ss:[ebp-9C],edi
0045B542 89BD 40FFFFFF mov dword ptr ss:[ebp-C0],edi
0045B548 89B5 0CFFFFFF mov dword ptr ss:[ebp-F4],esi
0045B54E FFD6 call esi
0045B550 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B553 50 push eax
0045B554 51 push ecx
0045B555 FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
0045B55B 8B10 mov edx,dword ptr ds:[eax]
0045B55D 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B560 51 push ecx
0045B561 50 push eax
0045B562 8985 3CFFFFFF mov dword ptr ss:[ebp-C4],eax
0045B568 FF92 A0000000 call dword ptr ds:[edx+A0]
0045B56E 3BC7 cmp eax,edi
0045B570 7D 18 jge short supernet.0045B58A
0045B572 8B95 3CFFFFFF mov edx,dword ptr ss:[ebp-C4]
0045B578 68 A0000000 push 0A0
0045B57D 68 10894000 push supernet.00408910
0045B582 52 push edx
0045B583 50 push eax
0045B584 FF15 08024600 call dword ptr ds:[<&MSVBVM50.__vbaHresultCheckObj>] ; MSVBVM50.__vbaHresultCheckObj
0045B58A 8B45 E0 mov eax,dword ptr ss:[ebp-20]
0045B58D 50 push eax
0045B58E 68 C88A4000 push supernet.00408AC8
0045B593 FF15 7C024600 call dword ptr ds:[<&MSVBVM50.__vbaStrCmp>] ; MSVBVM50.__vbaStrCmp
0045B599 F7D8 neg eax
0045B59B 1BC0 sbb eax,eax
0045B59D 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B5A0 F7D8 neg eax
0045B5A2 F7D8 neg eax
0045B5A4 8985 34FFFFFF mov dword ptr ss:[ebp-CC],eax
0045B5AA FF15 5C034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeStr>] ; MSVBVM50.__vbaFreeStr
0045B5B0 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B5B3 FF15 58034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeObj>] ; MSVBVM50.__vbaFreeObj
0045B5B9 66:39BD 34FFFFFF cmp word ptr ss:[ebp-CC],di
0045B5C0 0F84 500A0000 je supernet.0045C016
0045B5C6 53 push ebx
0045B5C7 FF95 0CFFFFFF call dword ptr ss:[ebp-F4]
0045B5CD 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B5D0 50 push eax
0045B5D1 51 push ecx
0045B5D2 FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
0045B5D8 8B10 mov edx,dword ptr ds:[eax]
0045B5DA 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B5DD 51 push ecx
0045B5DE 50 push eax
0045B5DF 8985 3CFFFFFF mov dword ptr ss:[ebp-C4],eax
0045B5E5 FF92 A0000000 call dword ptr ds:[edx+A0]
0045B5EB 3BC7 cmp eax,edi
0045B5ED 7D 18 jge short supernet.0045B607
0045B5EF 8B95 3CFFFFFF mov edx,dword ptr ss:[ebp-C4]
0045B5F5 68 A0000000 push 0A0
0045B5FA 68 10894000 push supernet.00408910
0045B5FF 52 push edx
0045B600 50 push eax
0045B601 FF15 08024600 call dword ptr ds:[<&MSVBVM50.__vbaHresultCheckObj>] ; MSVBVM50.__vbaHresultCheckObj
0045B607 8B45 E0 mov eax,dword ptr ss:[ebp-20]
0045B60A 50 push eax
0045B60B FF15 DC014600 call dword ptr ds:[<&MSVBVM50.__vbaLenBstr>] ; MSVBVM50.__vbaLenBstr
0045B611 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B614 8985 20FFFFFF mov dword ptr ss:[ebp-E0],eax
0045B61A BE 01000000 mov esi,1
0045B61F FF15 5C034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeStr>] ; MSVBVM50.__vbaFreeStr
0045B625 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B628 FF15 58034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeObj>] ; MSVBVM50.__vbaFreeObj
0045B62E 3BB5 20FFFFFF cmp esi,dword ptr ss:[ebp-E0]
0045B634 0F8F A6000000 jg supernet.0045B6E0
0045B63A 53 push ebx
0045B63B FF95 0CFFFFFF call dword ptr ss:[ebp-F4]
0045B641 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B644 50 push eax
0045B645 51 push ecx
0045B646 FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
0045B64C 8B45 C8 mov eax,dword ptr ss:[ebp-38]
0045B64F 8D55 A4 lea edx,dword ptr ss:[ebp-5C]
0045B652 8945 BC mov dword ptr ss:[ebp-44],eax
0045B655 52 push edx
0045B656 8D45 B4 lea eax,dword ptr ss:[ebp-4C]
0045B659 56 push esi
0045B65A 8D4D 94 lea ecx,dword ptr ss:[ebp-6C]
0045B65D 50 push eax
0045B65E 51 push ecx
0045B65F C745 AC 01000000 mov dword ptr ss:[ebp-54],1
0045B666 C745 A4 02000000 mov dword ptr ss:[ebp-5C],2
0045B66D C745 C8 00000000 mov dword ptr ss:[ebp-38],0
0045B674 C745 B4 09000000 mov dword ptr ss:[ebp-4C],9
0045B67B FF15 68024600 call dword ptr ds:[<&MSVBVM50.#632>] ; MSVBVM50.rtcMidCharVar
0045B681 8D55 94 lea edx,dword ptr ss:[ebp-6C]
0045B684 8D45 E0 lea eax,dword ptr ss:[ebp-20]
0045B687 52 push edx
0045B688 50 push eax
0045B689 FF15 CC024600 call dword ptr ds:[<&MSVBVM50.__vbaStrVarVal>] ; MSVBVM50.__vbaStrVarVal
0045B68F 50 push eax
0045B690 FF15 F8014600 call dword ptr ds:[<&MSVBVM50.#516>] ; MSVBVM50.rtcAnsiValueBstr
0045B696 0FBFC8 movsx ecx,ax
0045B699 03CF add ecx,edi ; // 用户名ASCII码累加和到ecx
0045B69B 0F80 850A0000 jo supernet.0045C126
0045B6A1 8BF9 mov edi,ecx
0045B6A3 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B6A6 FF15 5C034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeStr>] ; MSVBVM50.__vbaFreeStr
0045B6AC 8D4D C8 lea ecx,dword ptr ss:[ebp-38]
0045B6AF FF15 58034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeObj>] ; MSVBVM50.__vbaFreeObj
0045B6B5 8D55 94 lea edx,dword ptr ss:[ebp-6C]
0045B6B8 8D45 A4 lea eax,dword ptr ss:[ebp-5C]
0045B6BB 52 push edx
0045B6BC 8D4D B4 lea ecx,dword ptr ss:[ebp-4C]
0045B6BF 50 push eax
0045B6C0 51 push ecx
0045B6C1 6A 03 push 3
0045B6C3 FF15 E8014600 call dword ptr ds:[<&MSVBVM50.__vbaFreeVarList>] ; MSVBVM50.__vbaFreeVarList
0045B6C9 B8 01000000 mov eax,1
0045B6CE 83C4 10 add esp,10
0045B6D1 03C6 add eax,esi
0045B6D3 0F80 4D0A0000 jo supernet.0045C126
0045B6D9 8BF0 mov esi,eax
0045B6DB ^ E9 4EFFFFFF jmp supernet.0045B62E
0045B6E0 A1 10E04500 mov eax,dword ptr ds:[45E010]
0045B6E5 85C0 test eax,eax
0045B6E7 75 19 jnz short supernet.0045B702
0045B6E9 8B1D E0024600 mov ebx,dword ptr ds:[<&MSVBVM50.__vbaNew2>] ; MSVBVM50.__vbaNew2
0045B6EF 68 10E04500 push supernet.0045E010
0045B6F4 68 1C634000 push supernet.0040631C
0045B6F9 FFD3 call ebx
0045B6FB A1 10E04500 mov eax,dword ptr ds:[45E010]
0045B700 EB 06 jmp short supernet.0045B708
0045B702 8B1D E0024600 mov ebx,dword ptr ds:[<&MSVBVM50.__vbaNew2>] ; MSVBVM50.__vbaNew2
0045B708 85C0 test eax,eax
0045B70A 8985 2CFFFFFF mov dword ptr ss:[ebp-D4],eax
0045B710 75 11 jnz short supernet.0045B723
0045B712 68 10E04500 push supernet.0045E010
0045B717 68 1C634000 push supernet.0040631C
0045B71C FFD3 call ebx
0045B71E A1 10E04500 mov eax,dword ptr ds:[45E010]
0045B723 8B10 mov edx,dword ptr ds:[eax]
0045B725 50 push eax
0045B726 FF92 00030000 call dword ptr ds:[edx+300]
0045B72C 50 push eax
0045B72D 8D45 C8 lea eax,dword ptr ss:[ebp-38]
0045B730 50 push eax
0045B731 FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
0045B737 8BF0 mov esi,eax
0045B739 8D55 E0 lea edx,dword ptr ss:[ebp-20]
0045B73C 52 push edx
0045B73D 56 push esi
0045B73E 8B0E mov ecx,dword ptr ds:[esi]
0045B740 FF91 A0000000 call dword ptr ds:[ecx+A0]
0045B746 85C0 test eax,eax
0045B748 7D 12 jge short supernet.0045B75C
0045B74A 68 A0000000 push 0A0
0045B74F 68 10894000 push supernet.00408910
0045B754 56 push esi
0045B755 50 push eax
0045B756 FF15 08024600 call dword ptr ds:[<&MSVBVM50.__vbaHresultCheckObj>] ; MSVBVM50.__vbaHresultCheckObj
0045B75C A1 10E04500 mov eax,dword ptr ds:[45E010]
0045B761 85C0 test eax,eax
0045B763 75 11 jnz short supernet.0045B776
0045B765 68 10E04500 push supernet.0045E010
0045B76A 68 1C634000 push supernet.0040631C
0045B76F FFD3 call ebx
0045B771 A1 10E04500 mov eax,dword ptr ds:[45E010]
0045B776 8B08 mov ecx,dword ptr ds:[eax]
0045B778 50 push eax
0045B779 FF91 00030000 call dword ptr ds:[ecx+300]
0045B77F 8D55 C4 lea edx,dword ptr ss:[ebp-3C]
0045B782 50 push eax
0045B783 52 push edx
省略N行 代码
0045B784 FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
0045B78A 8BF0 mov esi,eax
0045B78C 8D4D DC lea ecx,dword ptr ss:[ebp-24]
0045B78F 51 push ecx
0045B790 56 push esi
0045B791 8B06 mov eax,dword ptr ds:[esi]
0045B793 FF90 A0000000 call dword ptr ds:[eax+A0]
0045B799 85C0 test eax,eax
0045B79B 7D 12 jge short supernet.0045B7AF
0045B79D 68 A0000000 push 0A0
0045B7A2 68 10894000 push supernet.00408910
0045B7A7 56 push esi
0045B7A8 50 push eax
0045B7A9 FF15 08024600 call dword ptr ds:[<&MSVBVM50.__vbaHresultCheckObj>] ; MSVBVM50.__vbaHresultCheckObj
0045B7AF 8B95 2CFFFFFF mov edx,dword ptr ss:[ebp-D4]
0045B7B5 8B45 DC mov eax,dword ptr ss:[ebp-24]
0045B7B8 50 push eax
0045B7B9 8B1A mov ebx,dword ptr ds:[edx]
0045B7BB FF15 60034600 call dword ptr ds:[<&MSVBVM50.#581>] ; MSVBVM50.rtcR8ValFromBstr
0045B7C1 FF15 24034600 call dword ptr ds:[<&MSVBVM50.__vbaFpI4>] ; MSVBVM50.__vbaFpI4
0045B7C7 99 cdq
0045B7C8 B9 E8030000 mov ecx,3E8 ; // A%=3E8 记为B
0045B7CD F7F9 idiv ecx
0045B7CF 8BF2 mov esi,edx
0045B7D1 8B55 E0 mov edx,dword ptr ss:[ebp-20]
0045B7D4 52 push edx
0045B7D5 FF15 60034600 call dword ptr ds:[<&MSVBVM50.#581>] ; MSVBVM50.rtcR8ValFromBstr
0045B7DB FF15 24034600 call dword ptr ds:[<&MSVBVM50.__vbaFpI4>] ; MSVBVM50.__vbaFpI4
0045B7E1 99 cdq
0045B7E2 B9 E8030000 mov ecx,3E8 ; // A%=3E8 记为C
0045B7E7 F7F9 idiv ecx
0045B7E9 0FAFF2 imul esi,edx ; // B*C 记为 D
0045B7EC 0F80 34090000 jo supernet.0045C126
0045B7F2 03F7 add esi,edi ; // D+=用户名ASCII码累加和
0045B7F4 0F80 2C090000 jo supernet.0045C126
0045B7FA 83C6 02 add esi,2 ; // D+=2
0045B7FD 0F80 23090000 jo supernet.0045C126
0045B803 46 inc esi ; // D++ 转10进制就是注册码
0045B804 0F80 1C090000 jo supernet.0045C126
0045B80A 56 push esi
0045B80B 8BB5 2CFFFFFF mov esi,dword ptr ss:[ebp-D4]
0045B811 56 push esi
0045B812 FF93 04070000 call dword ptr ds:[ebx+704]
0045B818 85C0 test eax,eax
省略N行 代码
0045B8D1 56 push esi
0045B8D2 50 push eax
0045B8D3 FF15 08024600 call dword ptr ds:[<&MSVBVM50.__vbaHresultCheckObj>] ; MSVBVM50.__vbaHresultCheckObj
0045B8D9 8B55 E0 mov edx,dword ptr ss:[ebp-20]
0045B8DC 52 push edx
0045B8DD FF15 60034600 call dword ptr ds:[<&MSVBVM50.#581>] ; MSVBVM50.rtcR8ValFromBstr
0045B8E3 FF15 5C024600 call dword ptr ds:[<&MSVBVM50.__vbaFpR8>] ; MSVBVM50.__vbaFpR8
0045B8E9 DB85 40FFFFFF fild dword ptr ss:[ebp-C0]
0045B8EF DD9D 04FFFFFF fstp qword ptr ss:[ebp-FC]
0045B8F5 DC9D 04FFFFFF fcomp qword ptr ss:[ebp-FC] ; //真假注册码比较
0045B8FB DFE0 fstsw ax
0045B8FD F6C4 40 test ah,40
0045B900 74 07 je short supernet.0045B909
0045B902 BE 01000000 mov esi,1
0045B907 EB 02 jmp short supernet.0045B90B
0045B909 33F6 xor esi,esi
0045B90B 8D4D E0 lea ecx,dword ptr ss:[ebp-20]
0045B90E FF15 5C034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeStr>] ; MSVBVM50.__vbaFreeStr
/////////////////////////////////////////////////////////////////////////////////////////////////
生成序列号的过程
/////////////////////////////////////////////////////////////////////////////////////////////////
通过搜索字符串看到 Iotmrd.sys 文件 就到这里下断
0042135A 51 push ecx
0042135B 52 push edx
0042135C C745 AC 00000000 mov dword ptr ss:[ebp-54],0
00421363 89BD 7CFFFFFF mov dword ptr ss:[ebp-84],edi
00421369 FF15 68024600 call dword ptr ds:[<&MSVBVM50.#632>] ; MSVBVM50.rtcMidCharVar
0042136F 8D85 5CFFFFFF lea eax,dword ptr ss:[ebp-A4]
00421375 8D8D 2CFFFFFF lea ecx,dword ptr ss:[ebp-D4]
0042137B 50 push eax
0042137C 8D95 4CFFFFFF lea edx,dword ptr ss:[ebp-B4]
00421382 51 push ecx
00421383 52 push edx
00421384 C785 34FFFFFF 288A40>mov dword ptr ss:[ebp-CC],supernet.00408A28 ; UNICODE "\Iotmrd.sys"
0042138E 89BD 2CFFFFFF mov dword ptr ss:[ebp-D4],edi
00421394 8D5E 34 lea ebx,dword ptr ds:[esi+34]
00421397 FF15 14034600 call dword ptr ds:[<&MSVBVM50.__vbaVarAdd>] ; MSVBVM50.__vbaVarAdd
0042139D 50 push eax
0042139E FF15 D8014600 call dword ptr ds:[<&MSVBVM50.__vbaStrVarMove>] ; MSVBVM50.__vbaStrVarMove
004213A4 8BD0 mov edx,eax
004213A6 8D4D A8 lea ecx,dword ptr ss:[ebp-58]
004213A9 FF15 30034600 call dword ptr ds:[<&MSVBVM50.__vbaStrMove>] ; MSVBVM50.__vbaStrMove
004213AF 8B3D F8024600 mov edi,dword ptr ds:[<&MSVBVM50.__vbaStrCopy>] ; MSVBVM50.__vbaStrCopy
004213B5 8BD0 mov edx,eax
004213B7 8BCB mov ecx,ebx
004213B9 FFD7 call edi
004213BB 8D4D A8 lea ecx,dword ptr ss:[ebp-58]
004213BE FF15 5C034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeStr>] ; MSVBVM50.__vbaFreeStr
004213C4 8D4D 98 lea ecx,dword ptr ss:[ebp-68]
004213C7 FF15 58034600 call dword ptr ds:[<&MSVBVM50.__vbaFreeObj>] ; MSVBVM50.__vbaFreeObj
004213CD 8D85 4CFFFFFF lea eax,dword ptr ss:[ebp-B4]
004213D3 8D8D 5CFFFFFF lea ecx,dword ptr ss:[ebp-A4]
004213D9 50 push eax
004213DA 8D95 6CFFFFFF lea edx,dword ptr ss:[ebp-94]
004213E0 51 push ecx
004213E1 8D85 7CFFFFFF lea eax,dword ptr ss:[ebp-84]
004213E7 52 push edx
004213E8 50 push eax
004213E9 6A 04 push 4
004213EB FF15 E8014600 call dword ptr ds:[<&MSVBVM50.__vbaFreeVarList>] ; MSVBVM50.__vbaFreeVarList
004213F1 83C4 14 add esp,14
004213F4 8D8D 7CFFFFFF lea ecx,dword ptr ss:[ebp-84]
004213FA 8D95 6CFFFFFF lea edx,dword ptr ss:[ebp-94]
00421400 C745 84 00000000 mov dword ptr ss:[ebp-7C],0
00421407 51 push ecx
00421408 68 FF000000 push 0FF
0042140D 52 push edx
0042140E C785 7CFFFFFF 020000>mov dword ptr ss:[ebp-84],2
00421418 FF15 C0024600 call dword ptr ds:[<&MSVBVM50.#607>] ; MSVBVM50.rtcStringVar
0042141E 8D85 6CFFFFFF lea eax,dword ptr ss:[ebp-94]
00421424 50 push eax
00421425 FF15 D8014600 call dword ptr ds:[<&MSVBVM50.__vbaStrVarMove>] ; MSVBVM50.__vbaStrVarMove
0042142B 8BD0 mov edx,eax
0042142D 8D4D B4 lea ecx,dword ptr ss:[ebp-4C]
00421430 FF15 30034600 call dword ptr ds:[<&MSVBVM50.__vbaStrMove>] ; MSVBVM50.__vbaStrMove
00421436 8D8D 6CFFFFFF lea ecx,dword ptr ss:[ebp-94]
0042143C 8D95 7CFFFFFF lea edx,dword ptr ss:[ebp-84]
00421442 51 push ecx
00421443 52 push edx
00421444 6A 02 push 2
00421446 FF15 E8014600 call dword ptr ds:[<&MSVBVM50.__vbaFreeVarList>] ; MSVBVM50.__vbaFreeVarList
0042144C 8B03 mov eax,dword ptr ds:[ebx]
0042144E 8B1D 18034600 mov ebx,dword ptr ds:[<&MSVBVM50.__vbaStrToAnsi>] ; MSVBVM50.__vbaStrToAnsi
00421454 83C4 0C add esp,0C
00421457 8D4D 9C lea ecx,dword ptr ss:[ebp-64]
0042145A 50 push eax
0042145B 51 push ecx
0042145C FFD3 call ebx
0042145E 8B55 B4 mov edx,dword ptr ss:[ebp-4C]
00421461 50 push eax
00421462 68 00010000 push 100
00421467 52 push edx
00421468 8D45 A0 lea eax,dword ptr ss:[ebp-60]
0042146B 50 push eax
0042146C FFD3 call ebx
00421EE9 D99D 14FFFFFF fstp dword ptr ss:[ebp-EC]
00421EEF D985 14FFFFFF fld dword ptr ss:[ebp-EC]
00421EF5 D80D 28104000 fmul dword ptr ds:[401028]
00421EFB DFE0 fstsw ax
00421EFD A8 0D test al,0D
00421EFF 0F85 C83E0000 jnz supernet.00425DCD
00421F05 FF15 38034600 call dword ptr ds:[<&MSVBVM50.__vbaR8IntI4>] ; MSVBVM50.__vbaR8IntI4
00421F0B 8D8D 7CFFFFFF lea ecx,dword ptr ss:[ebp-84]
00421F11 8BD8 mov ebx,eax
00421F13 FF15 D4014600 call dword ptr ds:[<&MSVBVM50.__vbaFreeVar>] ; MSVBVM50.__vbaFreeVar
00421F19 8BCB mov ecx,ebx
00421F1B 8B16 mov edx,dword ptr ds:[esi]
00421F1D 0FAFCB imul ecx,ebx ; //随机数A*=A;
00421F20 0F80 AC3E0000 jo supernet.00425DD2
00421F26 81C1 40420F00 add ecx,0F4240 ; //结果再加+0F4240 就是序列了
00421F2C 56 push esi ;
00421F2D 0F80 9F3E0000 jo supernet.00425DD2
00421F33 FF92 00030000 call dword ptr ds:[edx+300]
00421F39 50 push eax
00421F3A 8D45 98 lea eax,dword ptr ss:[ebp-68]
00421F3D 50 push eax
00421F3E FF15 2C024600 call dword ptr ds:[<&MSVBVM50.__vbaObjSet>] ; MSVBVM50.__vbaObjSet
00421F44 8B10 mov edx,dword ptr ds:[eax]
00421F46 53 push ebx
00421F47 8985 10FFFFFF mov dword ptr ss:[ebp-F0],eax
00421F4D 8995 8CFEFFFF mov dword ptr ss:[ebp-174],edx
00421F53 FF15 D0014600 call dword ptr ds:[<&MSVBVM50.__vbaStrI4>] ; MSVBVM50.__vbaStrI4
00421F59 8BD0 mov edx,eax
00421F5B 8D4D AC lea ecx,dword ptr ss:[ebp-54]
--------------------------------------------------------------------------------
【经验总结】
总结:
软件随机生成一个数 记为A
放在安装的根的Iotmrd.sys文件下目录 比如 我的就在
E:\Iotmrd.sys
文件内容如
[MyApp]
pt1=5949 // 随机数
pt2=Q
Form1Top= 2580
Form1Left= 2250
Form1Height= 11400
Form1Width= 14400
pt3= // 注册码
pt4= // 用户名
A=A*A
A+=F4240
转10进制 就是 序列号了
注册码就是这个 (随机数%3e8) 再平方 加用户名ASCII码累加和 再加3 转10进制
--------------------------------------------------------------------------------
【版权声明】: 本文原创于看雪技术论坛, 转载请注明作者并保持文章的完整, 谢谢!
2007年03月26日 22:02:36