Win7下文件过滤驱动中手工创建IRP重命名文件的问题

本文介绍了在Windows 7文件过滤驱动中遇到的重命名文件问题,以及如何使用IRP手动方式解决。通过分析系统调用流程和源码,找到了需要对文件对象进行特定处理的原因,最终成功实现了文件重命名操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    之前在写一个文件过滤驱动时遇到将文件移动到另一个目录的需求,为了避免重入,首先想到的就是利用IoCreateFileSpecifyDeviceObjectHint获得其句柄并用ZwSetInformationFile将其移动到另一目录,但测试时发现ZwSetInformationFile始终返回STATUS_INVALID_DEVICE_OBJECT_PARAMETER错误。

  

    上网搜了一下,发现有位仁兄也遇到了同样的问题(http://www.eggheadcafe.com/software/aspnet/31694886/rename-fails-on-handle-ob.aspx),跟踪了一下,发现系统用IopGetFileObjectExtension返回的值作为PDEVICE_OBJECT类型传入到IoCreateFileEx中,而实际上IopGetFileObjectExtension返回的是一个指向PDEVICE_OBJECT的指针,即指针的指针。

 

  

 

    手工在内存中更改该参数后ZwSetInformationFile返回成功,并且文件也正确移动到了指定的目录。这个错误也许是文件对象扩展的格式更改了,也许是IopOpenLinkOrRenameTarget内部代码更改了没同步,总之,现在只有通过手工创建IRP的方式来绕过这个问题。

 

     利用IRP的方式意味着不能用文件句柄了,只有自己打开文件对象并发送IRP。

 

     首先需要打开要移动的文件,获得文件对象:

 

    手工打开及关闭文件的接口:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值