Filemon中获取文件全路径方法

     FileMon中获取文件全路径的方法中最为关键的技术是通过自己下发IRP给下层驱动。下发请求的cmd为FileNameInformation或其他,具体请看代码。而在filespy中的获取的全路径的方法是通过ObQueryNameString()函数得到的。ObQueryNameString这个函数只能在打开IRP(IRP_MJ_CREATE)和清除(IRP_MJ_CLEANUP)或者关闭(IRP_MJ_CLOSE)IRP的处理中使用,否则很容易锁死,而用IRP的方式却没有这个问题。通过查看wrk相关代码,发现ObQueryNameString这个函数是首先检查默认对象查询名称函数是否存在,如存在则直接调用之,否则是用一种比较复杂的方法得到,这一部分的代码,贴在下面。我们注意到在FileObject对象中有一个FileName域,但是这个域是可以被其他过滤驱动修改的,也就是说通过这个域得到的数据不一定是真实的。

 

   FileMon获取文件全路径方法:

 

 

 

 

  ObQueryNameString中获取方法:

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值