Sandboxie源码分析(文件系统篇)

Sandboxie的原理是为进程创造隔离的环境,分别从文件系统、进程运行、安全令牌、网络等诸多方面进行。
本篇从文件系统入手,看看Sandboxie是如何从文件系统进行隔离的。

Sandboxie加载程序时,会将SbieDll.dll注入到程序中。
Dll_InitInjected()对许多模块进行了初始化:
初始化
其中,File_Init()对文件系统进行初始化。
如下图,它对许多Win API进行了hook,本篇主要对NtCreateFile进行大致分析。
SBIEDLL_HOOK
顺便一提,SBIEDLL_HOOK利用了hook原理,分析汇编指令,找到函数入口点,修改入口点指令/函数头部指令,使其跳转到我们自定义实现的函数中。
SbieDll_Hook
NtCreateFile最终会跳转到File_NtCreateFileImpl()。(虽然函数有一千多行,但其中有一部分都是注释,还有很多都是对特殊情况的处理,所以只要大致看主干,并且配合GPT对函数的解

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值