Hook ZwSetInformationFile, 根据目标路径拦截MoveFile移动文件

Hook ZwSetInformationFile, 根据目标路径拦截MoveFile移动文件
MoveFile的形式为:MoveFile( LPCTSTR lpExistingFileName, LPCTSTR lpNewFileName),现需要根据
lpNewFileName的路径来判断是否可以移动,在这我们Hook ZwSetInformationFile实现的,跟踪MoveFile可知,
它会调用ZwSetInformationFile实现文件移动功能,此时FileInformationClass为0x0A,且FileInformation的
结构_FILE_RENAME_INFORMATION是未公开的,逆向可得其结构:
typedef struct _FILE_RENAME_INFORMATION {
BOOLEAN ReplaceIfExists;
HANDLE RootDirectory;
ULONG FileNameLength;
WCHAR FileName[1];
} FILE_RENAME_INFORMATION, *PFILE_RENAME_INFORMATION;
Hook ZwSetInformationFile,当FileInformationClass等于0x0A时,从FILE_RENAME_INFORMATION结构中取出
FileName(其长度为FileNameLength),这就是宽字符的lpNewFileName。然后作判断。

ZwSetInformationFile形式:
NTSTATUS
ZwSetInformationFile(
IN HANDLE FileHandle,
OUT PIO_STATUS_BLOCK IoStatusBlock,
IN PVOID FileInformation,
IN ULONG Length,
IN FILE_INFORMATION_CLASS FileInformationClass
);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值