Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.04.03;
Скачать: CL | DM;

Вниз

int 21h   Найти похожие ветки 

 
unregistered   (2003-03-17 15:57) [0]

Можно ли написать резидентную программу на Паскале, которая будет перехватывать прерывание 21h и отслеживать обращения к определенным файлам, а потом передавать управление старому обработчику int21h?


 
Vlad Oshin ©   (2003-03-17 16:03) [1]


> Можно



 
Ru ©   (2003-03-17 16:05) [2]

можно если осторожно


 
NetBreaker666 ©   (2003-03-17 16:21) [3]

Такие вещи лучше на ASM"e писать.


 
Nic_B   (2003-03-17 16:32) [4]

Ну что-то типа этого (когда-то в молодости писал вири на паскале) может сгодится (но ассемблер знать надо). часть идеи выдрана из (с)Infected Voice

..
var
OldInt21: Pointer;
Regs: Registers;
..

{Свое прерывание int 21h}
procedure int21; Assembler;
asm
pushf
cmp ax,1235h
jnz @1
mov ax,1234h
popf
retf 2
@1:
push ax
push ds
xor ax,ax
mov ds,ax
cmp word ptr ds:[04F0H], 0DEADh
jnz @2 {@2}

xor ax,ax
mov ds,ax
mov word ptr ds:[04F0H], 0DEEDh

call create {а вот здесь вызывается то чего хочется запихнуть в обработчик}

pop ds
pop ax
popf
int 0e4h
retf 2

@2:
pop ds
pop ax
popf
int 0e4h
retf 2
end; {End of int 21h}
..
{main program}
begin
regs.AX:=$1235;
Intr($21,regs);
swapvectors;
if regs.AX<>$1234 then
begin
GetIntVec($21, OldInt21);
SetIntVec($21, Addr(Int21));
keep(0);
end;
end.



Страницы: 1 вся ветка

Текущий архив: 2003.04.03;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.019 c
14-6779
Greenering
2003-03-13 18:14
2003.04.03
SysUtils


14-6789
kostya2000
2003-03-16 23:36
2003.04.03
Отслеживаеться ли сканирование портов!?


14-6669
Jurd
2003-03-17 13:40
2003.04.03
Аспирантский реферат по философии


4-6860
Demn
2003-02-05 12:30
2003.04.03
Explorer, ListView и ListItem


14-6739
Malder
2003-03-15 16:19
2003.04.03
Главное меню в продуктах пакета Microsoft Office