dll注入设计

自己写一个简单的防泄露的小软件,记录一下:
主要是通过Dll注入的方式实现。
一. 防剪切拷贝
防剪切拷贝的功能通过dll注入系统剪切板的函数:“SetClipboardData”实现(包含在dll“User32.dll”里面)
<1>通过这种方式实现的防剪切拷贝的功能有以下特点:
(1) 可以防住快捷键(ctrl+c、ctrl+v、ctrl+x等)
(2) 可以防住系统右键快捷菜单里面出现的复制和拷贝
(3) 可以防住office等程序里面工具栏里面的复制和拷贝等功能
<2>不足:
(1) 应用程序通过window操作系统函数对文件进行读写拷贝的情况无法防范
<3>以下为被hook的api:
WINUSERAPI
HANDLE
WINAPI
SetClipboardData(
__in UINT uFormat,
__in_opt HANDLE hMem);

二. 防拖拽
防拖拽的功能现在能在office各个版本和window资源管理器上实现(日记本文档、visio、rtf下失效),通过dll注入系统的拖拽函数:“DoDragDrop”实现(包含在dll“Ole32.dll”里面)
<1>通过这种方式实现的防拖拽由以下特点:
(1) 可以防住程序之间对鼠标文字的拖放拷贝功能
<2>不足:
(1) 对程序直接文字的拖放拷贝直接hook,但这样对程序内部的拖放也会无效,要实现对程序内部可以拖放,程序间无法拖放,需要实时传入当前鼠标的坐标进行判断,实现会更为复杂些。
<3>以下为被hook的api:
DROPEFFECT DoDragDrop(LPCRECT lpRectItem, CPoint ptOffset,
BOOL bIncludeLink = FALSE,
DWORD dwEffects = DROPEFFECT_COPY|DROPEFFECT_MOVE,
LPCRECT lpRectStartDrag = NULL);

三.防打印
防打印的功能现在能在office各个版本和window资源管理器上实现,通过dll注入系统gid库中与打开打印机相关的函数:“StartDocW”和“StartDocA”实现(包含在dll“gdi32.dll”里面)
<1>通过这种方式实现的防拖拽由以下特点:
(1) 可以防住程序对文件的打印功能
<2>不足:
(1) 无法防住对文件的另存为pdf和虚拟打印机的功能
(2) Adobe Reader运行时有两个进程AcroRd32.exe,必须hook住其中的有效进程
<3>以下为被hook的api:
__gdi_entry WINGDIAPI int WINAPI StartDocA(__in HDC hdc, __in CONST DOCINFOA *lpdi);
__gdi_entry WINGDIAPI int WINAPI StartDocW(__in HDC hdc, __in CONST DOCINFOW *lpdi);

ifdef UNICODE

define StartDoc StartDocW

else

define StartDoc StartDocA

<4>说明:对于我测过的大部分程序(包括pdf、offic、wps、txt等等),进行打印时,都是调用操作系统中的可执行程序:PrintIsolationHost.exe执行打印操作的,所以直接hook打印操作并不可取(因为不在同一个进程)。因此,hook主准备开始打印的操作“StartDocW“和“StartDocA“,的方案即可。

四.防另存为
防另存为的功能现在能在office各个版本和window资源管理器上实现,通过dll注入系统中与打开窗口有关的函数:“ShowWindow”和“SetWindowPos”实现(包含在dll“User32.dll”里面)
<1>防另存为试过了很多种方法,最终都不是非常的理想,最后决定通过hook窗口函数进行实现。
<2>不足:
窗口函数的标题有很多种(有另存为、保存、以及多种语言的差别等等),需要全部hook住。
<3>以下为被hook的api:
void ShowWindow(
__in HWND hWnd,
__in int nCmdShow);
BOOL WINAPI SetWindowPos(
__in HWND hWnd,
__in_opt HWND hWndInsertAfter,
__in int X,
__in int Y,
__in int cx,
__in int cy,
__in UINT uFlags);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Delphi是一种编程语言,而DLL(Dynamic-Link Library)是一种模块化的文件格式,用于存储代码和数据,可以被多个应用程序共享。DLL注入是一种技术,它允许将DLL文件加载到正在运行的进程中,并使得该进程能够调用DLL中的函数和使用其中的数据。 在Delphi中实现DLL注入的方法有很多种。一种常见的方法是使用Windows API函数LoadLibrary和GetProcAddress。通过调用LoadLibrary函数,将DLL文件加载到进程的虚拟地址空间中。然后使用GetProcAddress函数获取DLL中导出函数的地址,并将其传递给需要调用的函数。通过这种方式,可以在运行时将DLL注入到目标进程中,并且通过调用DLL中的函数来扩展进程的功能。 DLL注入在实际应用中有多种用途。例如,可以使用DLL注入来为某个程序添加额外的功能或修改程序的行为。DLL注入还可以用于实现一些调试和监控的功能。通过注入DLL,可以截获程序的输入和输出,或者在程序执行某些指定的操作时进行额外的处理。 在Delphi中实现DLL注入需要一定的编程知识和技巧。需要考虑目标进程的架构和权限限制,以及如何管理注入DLL的生命周期和资源管理。同时,还需要处理一些安全性和稳定性方面的问题,以确保注入过程不会对目标进程造成损害或崩溃。 总之,Delphi可以通过调用Windows API函数来实现DLL注入,从而扩展和修改进程的功能。但在实际应用中,需要考虑各种方面的问题,并且遵守相关的法律和规定,以确保注入操作的安全性和合法性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

poet_lj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值