能力值:
( LV2,RANK:10 )
在线值:
|
-
-
2 楼
静态看不明白
是不是可以自己写一个小的程序来引用这个OCX控件
然后在合适的地方断点一下
来跟进去
要不然用OD没有办法来分析一个DLL啊
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
3 楼
是不是可以找到把这个字符串附加上去的代码
然后把这个跳过去
看完天龙八部试一试
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
4 楼
字符串的上面应该都有函数调用或是JNZ JE一类的东西.如果没有则需要修改某个标志位.能不能把弹出的对话框抓下来发到论坛里看一下
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
5 楼
.text:110029B4 push edi
.text:110029B5 add [ebp+0], ah
.text:110029B8 ins byte ptr es:[edi], dx
.text:110029B9 add [ebx+0], ah
.text:110029BC outsd
.text:110029BD add [ebp+0], ch
.text:110029C0 add gs:[eax], ah
.text:110029C3 add [eax+eax+6Fh], dh
.text:110029C7 add [eax], ah
.text:110029C9 add [eax+0], ch
.text:110029CC jz short $+2
.text:110029CE jz short $+2
.text:110029D0 jo short $+2
.text:110029D2 cmp al, [eax]
.text:110029D4 das
.text:110029D5 add [edi], ch
.text:110029D7 add [edi+0], dh
.text:110029DA ja short $+2
.text:110029DC ja short $+2
.text:110029DE add cs:[eax+eax+72h], dh
.text:110029E3 add [ecx+0], ah
.text:110029E6 outsb
.text:110029E7 add [ebx+0], dh
.text:110029EA outsd
.text:110029EB add [esi+0], ah
.text:110029EE jz short $+2
.text:110029F0 add cs:[ebx+0], ah
.text:110029F4 outsd
.text:110029F5 add [ebp+0], ch
.text:110029F8 add cs:[ebx+0], ah
.text:110029FC outsb
.text:110029FD add [edi], ch
.text:110029FF add [ebx+0], dh
.text:11002A02 ins dword ptr es:[edi], dx
.text:11002A03 add [ebx+0], dh
这段代码对应的就是那串讨厌的网址信息
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
6 楼
最初由 微笑一刀 发布 字符串的上面应该都有函数调用或是JNZ JE一类的东西.如果没有则需要修改某个标志位.能不能把弹出的对话框抓下来发到论坛里看一下
是这样的 这个控件是发送短信息用的
如果不注册话 你发送的信息内容前面就会被加上一个访问网址信息
注册之后就没有了
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
7 楼
最初由 gambol 发布
是这样的 这个控件是发送短信息用的 如果不注册话 你发送的信息内容前面就会被加上一个访问网址信息 注册之后就没有了
发送以后附带的是什么信息,能不能抓个图.因为不知道是什么信息分析起来麻烦.我总不能套用这个OCX写个软件在调试吧...
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
8 楼
最初由 微笑一刀 发布
发送以后附带的是什么信息,能不能抓个图.因为不知道是什么信息分析起来麻烦.我总不能套用这个OCX写个软件在调试吧...
用IDA PRO可以看到一个地方有
就是.text:110029b4处
有一个UNICODE字符串:“Welcome to http://www.tr........”
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
9 楼
还有就是
我把110029B4那里的字符串删除了 或者修改了 都没有效果
在实验的时候还是会出现那个字符串的
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
10 楼
请教一个非常初级的问题
就是在静态分析代码的时候
怎么判断寄存器中的值啊?
尤其代码比较长的时候
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
11 楼
.text:1100E4A0 push ebp
.text:1100E4A1 mov ebp, esp
.text:1100E4A3 sub esp, 14h
.text:1100E4A6 push offset loc_11001696
.text:1100E4AB mov eax, large fs:0
.text:1100E4B1 push eax
.text:1100E4B2 mov large fs:0, esp
.text:1100E4B9 sub esp, 194h
.text:1100E4BF push ebx
.text:1100E4C0 push esi
.text:1100E4C1 push edi
.text:1100E4C2 mov [ebp+var_14], esp
.text:1100E4C5 mov [ebp+var_10], offset dword_110014F8
.text:1100E4CC xor esi, esi
.text:1100E4CE mov [ebp+var_C], esi
.text:1100E4D1 mov [ebp+var_8], esi
.text:1100E4D4 mov [ebp+var_20], esi
.text:1100E4D7 mov [ebp+var_28], esi
.text:1100E4DA mov [ebp+var_2C], esi
.text:1100E4DD mov [ebp+var_30], esi
.text:1100E4E0 mov [ebp+var_34], esi
.text:1100E4E3 mov [ebp+var_38], esi
.text:1100E4E6 mov [ebp+var_48], esi
.text:1100E4E9 mov [ebp+var_58], esi
.text:1100E4EC mov [ebp+var_68], esi
.text:1100E4EF mov [ebp+var_78], esi
.text:1100E4F2 mov [ebp+var_88], esi
.text:1100E4F8 mov [ebp+var_98], esi
.text:1100E4FE mov [ebp+var_A8], esi
.text:1100E504 mov [ebp+var_B8], esi
.text:1100E50A mov [ebp+var_C8], esi
.text:1100E510 mov [ebp+var_D8], esi
.text:1100E516 mov [ebp+var_E8], esi
.text:1100E51C mov [ebp+var_F8], esi
.text:1100E522 mov edx, [ebp+arg_0]
.text:1100E525 lea ecx, [ebp+var_20]
.text:1100E528 mov edi, ds:__vbaStrCopy
.text:1100E52E call edi ; __vbaStrCopy
.text:1100E530 mov edx, [ebp+arg_4]
.text:1100E533 lea ecx, [ebp+var_30]
.text:1100E536 call edi ; __vbaStrCopy
.text:1100E538 mov edx, [ebp+arg_8]
.text:1100E53B lea ecx, [ebp+var_28]
.text:1100E53E call edi ; __vbaStrCopy
.text:1100E540 push 1
.text:1100E542 call ds:__vbaOnError
.text:1100E548 mov edx, offset dword_1100298C
.text:1100E54D lea ecx, [ebp+var_34]
.text:1100E550 call edi ; __vbaStrCopy
.text:1100E552 mov ebx, [ebp+arg_C]
.text:1100E555 mov [ebx], si
.text:1100E558 mov eax, [ebp+var_28]
.text:1100E55B push eax
.text:1100E55C mov edi, ds:__vbaLenBstr
.text:1100E562 call edi ; __vbaLenBstr
.text:1100E564 mov [ebp+var_10C], eax
.text:1100E56A fild [ebp+var_10C]
.text:1100E570 fstp [ebp+var_114]
.text:1100E576 fld [ebp+var_114]
.text:1100E57C cmp dword_11015000, 0
.text:1100E583 jnz short loc_1100E58D
.text:1100E585 fdiv ds:dbl_11001490
.text:1100E58B jmp short loc_1100E59E
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
12 楼
.text:1100E57C cmp dword_11015000, 0
.text:1100E583 jnz short loc_1100E58D
.text:1100E585 fdiv ds:dbl_11001490
.text:1100E58B jmp short loc_1100E59E
上面代码是不是就是来进行判断的啊
.data:11015000 ; Section 2. (virtual address 00015000)
.data:11015000 ; Virtual size : 00000DAC ( 3500.)
.data:11015000 ; Section size in file : 00001000 ( 4096.)
.data:11015000 ; Offset to raw data for section: 00015000
.data:11015000 ; Flags C0000040: Data Readable Writable
.data:11015000 ; Alignment : 16 bytes ?
.data:11015000 ; ÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍÍ
.data:11015000
.data:11015000 ; Segment type: Pure data
.data:11015000 ; Segment permissions: Read/Write
.data:11015000 _data segment para public 'DATA' use32
.data:11015000 assume cs:_data
.data:11015000 ;org 11015000h
.data:11015000 unk_11015000 db 0 ; ; DATA XREF: .text:11001E20o
.data:11015000 ; sub_1100ACB0+5BAr ...
.data:11015001 db 0 ;
.data:11015002 db 0 ;
.data:11015003 db 0 ;
.data:11015004 db 0 ;
.data:11015005 db 0 ;
.data:11015006 db 0 ;
.data:11015007 db 0 ;
.data:11015008 unk_11015008 db 0 ; ; DATA XREF: .text:11001E18o
.data:11015008 ; .text:110022A8o
.data:11015009 db 0 ;
.data:1101500A db 0 ;
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
13 楼
自己还是没有搞明白
希望大侠指点
晕死了
|
能力值:
( LV2,RANK:10 )
|
-
-
14 楼
可以使用olldbg1.10b 来加载dll的方法动态调试
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
15 楼
哪位能帮助分析一下这个OCX
实在是着急
等我自己研究明白 怕来不及啊
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
16 楼
|
能力值:
( LV2,RANK:10 )
|
-
-
17 楼
你只有一个OCX怎么分析???OCX与DLL分析方法一样
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
18 楼
静态分析不行吗?
|
能力值:
( LV2,RANK:10 )
|
-
-
19 楼
你去原来的论坛找一找
我记得有一个破解SMSreg.exe的帖子
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
20 楼
我现在已经可以把这个控件注册了
目前是希望研究一下这个控件
希望找到OCX中的字符串位置
我找到的那个很明显的不对
修改或者删除都没有彻底解决 应该在OCX中还有其他的地方有这个串
|
能力值:
(RANK:380 )
|
-
-
21 楼
最初由 gambol 发布 我现在已经可以把这个控件注册了
目前是希望研究一下这个控件
希望找到OCX中的字符串位置
我找到的那个很明显的不对
修改或者删除都没有彻底解决 应该在OCX中还有其他的地方有这个串
不一定全是明文有可能经过转换动态跟踪看看吧
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
22 楼
对于OCX控件的动态调试没有试过
我的想法是:
为这个OCX控件开设一个工程
然后分析这个OCX文件
晚上我实验一下
不知道这样的思路对吗?
不知道有没有专门的调试OCX控件(DLL)的工具啊?
|
能力值:
( LV2,RANK:10 )
|
-
-
23 楼
我认为控件注册有两种,一种是在开发环境下注册,注册以后再发布编译过的程序就没有广告了,这一种控件运行时是有可能不检测是否注册。
二是在编程时在源程序中给一个调用参数:注册码,在发布以后也是没有广告了,但这一种控件运行实际上还是在检测是否注册。
这两种情况我都碰到过,但不知你的注册属于哪一种?
另外,最好给出一个简单的工程,或编译好的程序。
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
24 楼
我生成了一个工程 其中使用了这个控件
在控件的.H文件中我找到了那个函数
InvokeHelper(0x6003000c,......
使用IDA PRO查看0x6003000c得到地址是00416740
可是这个地址是哪里的地址?
我在用OD动态跟踪的时候怎么从这个地址开始跟踪啊?
|
能力值:
( LV2,RANK:10 )
在线值:
|
-
-
25 楼
怎么设置断点才可以跟踪到OCX里面的代码呢?
|
|
|