文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 国产软件 | 国外软件 | 汉化补丁 | 设为首页 | 加入收藏
网站首页 软件下载
数码学院 网络学院
业界资讯 | 图形图像 | 操作系统 | 网络冲浪 | 工具软件 | 办公软件 | 媒体动画 | 精文荟萃 | 认证考试 | 网站建设 | 技术开发 | 专栏
当前位置:abcdown网络学院程序开发Delphi拦截其它程序的网络数据封包
精品广告
推荐TOP10
·利用Delphi编写Socket通信程序
·拦截其它程序的网络数据封包
·Delphi编程根据IP地址得到主机名
·Delphi 程序员代码编写标准指南
·用DELPHI开发自动化服务器
·将日期转化为汉语的形式
·加密ACCESS数据库增加安全性
·使用TCP/IP协议实现聊天程序
·在Delphi中控制扫描仪
阅读TOP10
·在Delphi中控制扫描仪
·Delphi中DLL的创建和使用(1)
·DELPHI多层分布式开发(2)
·利用Delphi 5.0开发OLE自动化控制器操纵Excel
·实现高速文件拷贝
·Delphi下“培养”自己的简单木马
·DELPHI多层分布式开发(1)
·DBGrid使用全书(三)
·Delphi多层开发方案比较
·Delphi 6 SOAP 源码中的BUG修正
·ASC II 完整码表及简介
·小技巧:如何用Delphi创建快捷方式
·Delphi基础开发技巧(1)
·Delphi中利用钩子实现QQ聊天窗口的修改
·先人的DELPHI基础开发技巧
·Delphi编程根据IP地址得到主机名
·如何Delphi中操纵拨号网络
·实现关键字查找word文档里相匹配的内容
·用Delphi实现WinSocket高级应用
·利用Delphi编写Socket通信程序

拦截其它程序的网络数据封包

日期:2007年8月16日 作者: 查看:[大字体 中字体 小字体]


有时候我们需要对其它应用程序发送和接收的网络数据进行拦截,比如要对IE发送的HTTP头进行分析,得到请求的地址等.这次我们可以用一些例如WPE, Sniffer之类的工具来达到目的.但是工具功能有限,要想实现更强大的功能,还是我们自己动手吧.

拦截网络数据封包的方法有三种,一是将网卡设为混杂模式,这次就可以监视到局域网上所有的数据包,二是HOOK目标进程的发送和接收的API函数,第三种方法是自己实现一个代理的DLL.在这里我们使用HOOK API的方法,这样易于实现,而且也不会得到大量的无用数据(如第一种方法就会监视到所有的网络数据).

下面是一个尽量简化了的API HOOK的模版,原理是利用消息钩子将DLL中的代码注入到目标进程中,再用GetProcAddress得到API函数入口地址,将函数入口址改为自己定义的函数入口,这样就得到了API函数的相应参数,处理完后,再改回真实API函数入口地址,并调用它.

HOOK.DLL的代码:

library Hook;

uses

SysUtils,

windows,

Messages,

APIHook in "APIHook.pas";

type

PData = ^TData;

TData = record

Hook: THandle;

Hooked: Boolean;

end;

var

DLLData: PData;

{------------------------------------}

{过程名:HookProc

{过程功能:HOOK过程

{过程参数:nCode, wParam, lParam消息的相

{ 关参数

{------------------------------------}

procedure HookProc(nCode, wParam, lParam: LongWORD);stdcall;

begin

if not DLLData^.Hooked then

begin

HookAPI;

DLLData^.Hooked := True;

end;

//调用下一个Hook

CallNextHookEx(DLLData^.Hook, nCode, wParam, lParam);

end;

{------------------------------------}

{函数名:InstallHook

{函数功能:在指定窗口上安装HOOK

{函数参数:sWindow:要安装HOOK的窗口

{返回值:成功返回TRUE,失败返回FALSE

{------------------------------------}

function InstallHook(SWindow: LongWORD):Boolean;stdcall;

var

ThreadID: LongWORD;

begin

Result := False;

DLLData^.Hook := 0;

ThreadID := GetWindowThreadProcessId(sWindow, nil);

//给指定窗口挂上钩子

DLLData^.Hook := SetWindowsHookEx(WH_GETMESSAGE, @HookProc, Hinstance, ThreadID);

if DLLData^.Hook > 0 then

Result := True //是否成功HOOK

else

exit;

end;

{------------------------------------}

{过程名:UnHook

{过程功能:卸载HOOK

{过程参数:无

{------------------------------------}

procedure UnHook;stdcall;

[1] [2] [3] [4] [5] 下一页 

上一篇:压缩图像文件并转换成BMP格式

下一篇:Delphi使用VB编写的ActiveX控件全攻略


相关软件: 相关文章:
·利用HOOK拦截封包原理
·拦截Windows消息--C++ Builder的API后门
·拦截其它程序的网络数据封包
·研究报告称垃圾邮件过滤技术拦截率已达96%
·网页挂马拦截防护性能大比拼
·谁是克星?4款网页木马拦截工具大比武
·C#+低级Windows API钩子拦截键盘输入
·如何防止被IE工具拦截导致无法弹出窗口
·三招八式教你拦截烦人的网上广告
·你的插件拦截智能吗?

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.abcdown.net
首页 | 本站声明 | 下载帮助 | 发布软件 |
中文版权所有:ABC学院 浙ICP备05000717号