三维成绩评估系统[教研室版]V2006 破解
程序用upx压缩,入口点在0042ABBB,用OD在运行到该点,然后脱壳(脱壳后文件较大)0042ABB8 >68 9C534400 push 0044539C
0042ABBD E8 EEFFFFFF call <jmp.&MSVBVM60.ThunRTMain>
进入后,打开注册窗口,输入信息后进行注册,显示错误信息,在OD中F12暂停程序,在堆栈中可发现程序调用对话框后的返回点
00C9A3DC 50 push eax
00C9A3DD C745 C0 084>mov dword ptr , 4008 ; 显示输入错误信息
00C9A3E4 FF15 9C1040>call [<&MSVBVM60.rtcMsgBox>] ; MSVBVM60.rtcMsgBox
。。。。
向上可来到注册处理函数的开始点,在开始点设置断点.
==================================
0108A6E8 50 push eax
0108A6E9 68 34A>push 0047AE34
0108A6EE FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108A6F4 F7D8 neg eax ; EAX=(NAME=="")
......
0108A712 8D4D D>lea ecx,
0108A715 FF15 9>call [<&MSVBVM60.__vbaFreeObj>] ; MSVBVM60.__vbaFreeObj
0108A71B 0FBF4D>movsx ecx, word ptr
0108A71F 85C9 test ecx, ecx
0108A721 0F84 C>je 0108A7E8 ; 如果Name="",则不跳,并显示错误
....
0108A851 50 push eax ; =DATE=2006-03-01
0108A852 FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108A858 8BD0 mov edx, eax
0108A85A 8D4D D>lea ecx,
0108A85D FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108A863 50 push eax
0108A864 68 34A>push 0047AE34
0108A869 FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108A86F F7D8 neg eax ; EAX=(DATE=="")
....
0108A896 0FBF45>movsx eax, word ptr
0108A89A 85C0 test eax, eax
0108A89C 0F84 C>je 0108A969 ; 如果DATE为空,则不跳,并显示错误
....
0108A9D5 8B55 D>mov edx,
0108A9D8 52 push edx ; =KEY=机器码=1817-18B2-E81A-EA18
0108A9D9 FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108A9DF 8BD0 mov edx, eax
0108A9E1 8D4D D>lea ecx,
0108A9E4 FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108A9EA 50 push eax
0108A9EB 68 34A>push 0047AE34
0108A9F0 FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108A9F6 F7D8 neg eax ; EAX=(KEY=="")
....
0108AA1D 0FBF55>movsx edx, word ptr
0108AA21 85D2 test edx, edx
0108AA23 0F84 C>je 0108AAF0 ; 如果key为空,则不跳,并显示错误
...
0108AB5F 51 push ecx ; SN1="1234"
0108AB60 FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108AB66 8BD0 mov edx, eax
0108AB68 8D4D D>lea ecx,
0108AB6B FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108AB71 50 push eax
0108AB72 68 34A>push 0047AE34
0108AB77 FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108AB7D F7D8 neg eax ; EAX=(SN1=="")
....
0108ABA4 0FBF4D>movsx ecx, word ptr
0108ABA8 85C9 test ecx, ecx
0108ABAA 0F84 C>je 0108AC77 ; 若SN1="",则不跳并显示错误
....
0108ACE6 50 push eax ; SN2="5678"
0108ACE7 FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108ACED 8BD0 mov edx, eax
0108ACEF 8D4D D>lea ecx,
0108ACF2 FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108ACF8 50 push eax
0108ACF9 68 34A>push 0047AE34
0108ACFE FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108AD04 F7D8 neg eax ; EAX=(SN2=="")
....
0108AD2B 0FBF45>movsx eax, word ptr
0108AD2F 85C0 test eax, eax
0108AD31 0F84 C>je 0108ADFE
...
0108AE6D 52 push edx ; EDX=SN3="1234"
0108AE6E FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108AE74 8BD0 mov edx, eax
0108AE76 8D4D D>lea ecx,
0108AE79 FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108AE7F 50 push eax
0108AE80 68 34A>push 0047AE34
0108AE85 FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108AE8B F7D8 neg eax
....
0108AFF4 51 push ecx ; SN4="5678"
0108AFF5 FF15 4>call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108AFFB 8BD0 mov edx, eax
0108AFFD 8D4D D>lea ecx,
0108B000 FF15 6>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108B006 50 push eax
0108B007 68 34A>push 0047AE34
0108B00C FF15 0>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108B012 F7D8 neg eax
....
0108C6D9 FF90 00070000 call ; 判断输入的各个数据是否有空的,无空则EAX=0
0108C6DF 8985 44FFFFFF mov , eax
0108C6E5 83BD 44FFFFFF>cmp dword ptr , 0
0108C6EC 7D 23 jge short 0108C711
....
0108C7D2 52 push edx ; =NAME="SPC_CLL"
0108C7D3 FF15 4C104000 call [<&MSVBVM60.rtcTrimBstr>] ; MSVBVM60.rtcTrimBstr
0108C7D9 8BD0 mov edx, eax
0108C7DB 8D4D C8 lea ecx,
0108C7DE FF15 68124000 call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108C7E4 50 push eax
0108C7E5 68 34AE4700 push 0047AE34
0108C7EA FF15 00114000 call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108C7F0 F7D8 neg eax ; EAX=(NAME=="")
....
0108CCCC 68 0>push 00484E00 ; UNICODE "$#@^*()~"
0108CCD1 8B95>mov edx,
0108CCD7 8D4D>lea ecx,
0108CCDA FF15>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108CCE0 50 push eax ; =KEY
0108CCE1 FF15>call [<&MSVBVM60.__vbaStrCat>] ; MSVBVM60.__vbaStrCat
0108CCE7 8BD0 mov edx, eax ; EAX=CH1="$#@^*()~"+KEY
0108CCE9 8D4D>lea ecx,
0108CCEC FF15>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108CCF2 8B45>mov eax, ; =NAME
0108CCF5 8985>mov , eax
0108CCFB C745>mov dword ptr , 0
0108CD02 8B95>mov edx, ; =NAME
0108CD08 8D4D>lea ecx,
0108CD0B FF15>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108CD11 50 push eax ; =>[]=NAME
0108CD12 68 F>push 00484DF4 ; CH2=20 5F 0F 5C 1B 74
0108CD17 FF15>call [<&MSVBVM60.__vbaStrCat>] ; MSVBVM60.__vbaStrCat
0108CD1D 8985>mov , eax ; EAX=CH3=NAME+CH2
0108CD23 C785>mov dword ptr , 8
0108CD2D 8D8D>lea ecx,
0108CD33 51 push ecx ; 0
0108CD34 8D55>lea edx,
0108CD37 52 push edx ; CH1="$#@^*()~"+KEY
0108CD38 8D85>lea eax,
0108CD3E 50 push eax ; CH3=NAME+CH2
0108CD3F E8 6CA5C0F>call 00C972B0 ; eax=snx=Fun(ch3,ch1)=1415-16C6-14A7-135E
======>>>>>>==============
......
00179FC800 00 2E 00 59 00 8E 00 3F 00 E7 00 20 00 81 00....Y.??.? .?
00179FD833 00 1C 00 61 00 F8 00 29 00 88 00 35 00 4E 003..a.?).?5.N.
00179FE8A4 ?
.....
00C98619 66:8B8D 48>mov cx,
00C98620 66:038D 38>add cx, ; i=i+1=1.2.3.4=1..16
00C98627 0F80 F4090>jo <ErrorOverFlow>
00C9862D 66:898D 48>mov , cx
00C98634 66:8B95 48>mov dx,
00C9863B 66:3B95 34>cmp dx,
00C98642 0F8F BC010>jg 00C98804
00C98648 C745 FC 5E>mov dword ptr , 5E
00C9864F 0FBF85 0CF>movsx eax, word ptr
00C98656 8985 70FEF>mov , eax
00C9865C 83BD 70FEF>cmp dword ptr , 11
00C98663 73 0C jnb short 00C98671
00C98665 C785 9CFDF>mov dword ptr , 0
00C9866F EB 0C jmp short 00C9867D
00C98671 FF15 FC104>call [<&MSVBVM60.__vbaGenerateBoundsErro>; MSVBVM60.__vbaGenerateBoundsError
00C98677 8985 9CFDF>mov , eax
00C9867D C785 F4FEF>mov dword ptr , 1
00C98687 C785 ECFEF>mov dword ptr , 2
00C98691 8D8D 44FFF>lea ecx,
00C98697 898D B4FEF>mov , ecx
00C9869D C785 ACFEF>mov dword ptr , 4008
00C986A7 8D95 ECFEF>lea edx,
00C986AD 52 push edx ; 1
00C986AE 0FBF85 48F>movsx eax, word ptr
00C986B5 50 push eax ; 1
00C986B6 8D8D ACFEF>lea ecx,
00C986BC 51 push ecx ; ch3
00C986BD 8D95 DCFEF>lea edx,
00C986C3 52 push edx
00C986C4 FF15 E4104>call [<&MSVBVM60.rtcMidCharVar>] ; MSVBVM60.rtcMidCharVar
00C986CA 0FBF85 0CF>movsx eax, word ptr ; c1=mid(ch3,i,1)
00C986D1 8985 74FEF>mov , eax ; eax=1
00C986D7 83BD 74FEF>cmp dword ptr , 11
00C986DE 73 0C jnb short 00C986EC
00C986E0 C785 98FDF>mov dword ptr , 0
00C986EA EB 0C jmp short 00C986F8
00C986EC FF15 FC104>call [<&MSVBVM60.__vbaGenerateBoundsErro>; MSVBVM60.__vbaGenerateBoundsError
00C986F2 8985 98FDF>mov , eax
00C986F8 8D8D DCFEF>lea ecx,
00C986FE 51 push ecx
00C986FF 8D95 FCFEF>lea edx,
00C98705 52 push edx
00C98706 FF15 A8114>call [<&MSVBVM60.__vbaStrVarVal>] ; MSVBVM60.__vbaStrVarVal
00C9870C 50 push eax ; x1==val(c1)
00C9870D FF15 44104>call [<&MSVBVM60.rtcAnsiValueBstr>] ; MSVBVM60.rtcAnsiValueBstr
00C98713 8B8D 70FEF>mov ecx, ; eax=x1=val(c1),ecx=1
00C98719 8B95 2CFFF>mov edx,
00C9871F 66:8B0C4Amov cx,
00C98723 66:03C8 add cx, ax ; cx=d1+x1(数d1组初始为0)
00C98726 0F80 F5080>jo <ErrorOverFlow>
00C9872C 66:83F1 12 xor cx, 12 ; cx=(d1+x1) xor 12
00C98730 8B95 74FEF>mov edx,
00C98736 8B85 2CFFF>mov eax,
00C9873C 66:890C50mov , cx ; d1=(d1+x1) xor 12
00C98740 8D8D FCFEF>lea ecx,
00C98746 FF15 98124>call [<&MSVBVM60.__vbaFreeStr>] ; MSVBVM60.__vbaFreeStr
00C9874C 8D8D DCFEF>lea ecx,
00C98752 51 push ecx
00C98753 8D95 ECFEF>lea edx,
00C98759 52 push edx
00C9875A 6A 02 push 2
00C9875C FF15 38104>call [<&MSVBVM60.__vbaFreeVarList>] ; MSVBVM60.__vbaFreeVarList
00C98762 83C4 0C add esp, 0C
00C98765 C745 FC 5F>mov dword ptr , 5F
00C9876C 0FBF85 0CF>movsx eax, word ptr
00C98773 8985 74FEF>mov , eax
00C98779 83BD 74FEF>cmp dword ptr , 11
00C98780 73 0C jnb short 00C9878E
00C98782 C785 94FDF>mov dword ptr , 0
00C9878C EB 0C jmp short 00C9879A
00C9878E FF15 FC104>call [<&MSVBVM60.__vbaGenerateBoundsErro>; MSVBVM60.__vbaGenerateBoundsError
00C98794 8985 94FDF>mov , eax
00C9879A 8B8D 74FEF>mov ecx,
00C987A0 8B95 2CFFF>mov edx,
00C987A6 66:8B45 B4 mov ax, ; ax=z1(z1初始值为0)
00C987AA 66:03044Aadd ax, ; ax=d1
00C987AE 0F80 6D080>jo <ErrorOverFlow>
00C987B4 66:8945 B4 mov , ax ; z1=d1
00C987B8 C745 FC 60>mov dword ptr , 60
00C987BF 66:8B8D 0C>mov cx,
00C987C6 66:83C1 01 add cx, 1 ; i=i+1
00C987CA 0F80 51080>jo <ErrorOverFlow>
00C987D0 66:898D 0C>mov , cx
00C987D7 C745 FC 61>mov dword ptr , 61
00C987DE 66:83BD 0C>cmp word ptr , 9
00C987E6 75 10 jnz short 00C987F8
00C987E8 C745 FC 62>mov dword ptr , 62
00C987EF 66:C785 0C>mov word ptr , 1
00C987F8 C745 FC 64>mov dword ptr , 64
00C987FF^ E9 15FEFFF>jmp 00C98619
........
00C98EE1 8B55 B0 mov edx, ; 1415-16C6-14A7-135E
00C98EE4 8D8D 00FFF>lea ecx,
00C98EEA FF15 EC114>call [<&MSVBVM60.__vbaStrCopy>] ; MSVBVM60.__vbaStrCopy
:=001722EC
001722EC31 00 34 00 31 00 35 00 2D 00 31 00 36 00 43 001.4.1.5.-.1.6.C.
001722FC36 00 2D 00 31 00 34 00 41 00 37 00 2D 00 31 006.-.1.4.A.7.-.1.
0017230C33 00 35 00 45 3.5.E
.....
<<<<<<<<<===================
0108D11E C745>mov dword ptr , 27
0108D125 8B4D>mov ecx,
0108D128 51 push ecx ; sn
0108D129 FF15>call [<&MSVBVM60.rtcUpperCaseBstr>; MSVBVM60.rtcUpperCaseBstr
0108D12F 8BD0 mov edx, eax
0108D131 8D4D>lea ecx,
0108D134 FF15>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108D13A 50 push eax ; 输入的sn
0108D13B 8B55>mov edx,
0108D13E 52 push edx
0108D13F FF15>call [<&MSVBVM60.rtcUpperCaseBstr>; MSVBVM60.rtcUpperCaseBstr
0108D145 8BD0 mov edx, eax
0108D147 8D4D>lea ecx,
0108D14A FF15>call [<&MSVBVM60.__vbaStrMove>] ; MSVBVM60.__vbaStrMove
0108D150 50 push eax ; snx=1415-16C6-14A7-135E
0108D151 FF15>call [<&MSVBVM60.__vbaStrCmp>] ; MSVBVM60.__vbaStrCmp
0108D157 F7D8 neg eax ; eax=(snx==输入的SN)
****************************
** 程序使用了明码比较 **
****************************
注册后注册信息保存在系统目录下的jdrv.ocx中(在文件末尾) 怎么找不到呀!? ****************************
** 程序使用了明码比较 **
****************************
注册后注册信息保存在系统目录下的jdrv.ocx中
晕!
这个断点好!
00C9A3DD C745 C0 084>mov dword ptr , 4008 ; 显示输入错误信息
00C9A3E4 FF15 9C1040>call [<&MSVBVM60.rtcMsgBox>] ; MSVBVM60.rtcMsgBox
[ 本帖最后由 野猫III 于 2006-4-24 16:36 编辑 ] 不明白,不会,呵呵 学习,收藏!!支持!!!!
页:
[1]