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

本文深入探讨Sandboxie如何通过文件系统隔离来保护系统。它通过hook Win API,特别是NtCreateFile函数,对文件操作进行监控和控制。主要任务包括检查递归调用、文件类型(如管道和磁盘设备)、重定向策略,以及处理文件句柄、状态和访问权限。通过对函数的分析,揭示了沙箱技术的核心原理。

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

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

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

Sandboxie允许你在“沙盘环境”中运行浏览器或其他程序,这个“沙盘”个人感觉就是跟“影子”一样的概念罢了。因此,在沙盘中运行的程序所产生的变化可以随时删除。可用来保护浏览网页时真实系统的安全,也可以用来清除上网、运行程序的痕迹,还可以用来测试软件,测试病毒等用途。即使在沙盘进程中下载的文件,也可以随着沙盘的清空而删除。<br> Sandboxie一般是设置某个程序在“沙盘”中运行,而不是将整个Windows都置于“影子”模式下。也就是可以很灵活地设置一个或几个觉得“危险”的程序运行在“沙盘”,而其他一切则正常运行。<br>(1)、上网无忧,用SandBoxie在沙盘中运行浏览器 <br>  我们打开SandBoxie后,在右下角的图标中右键选择“运行沙盘→IE浏览器”,这时候会自动弹出标题栏中有两个“[#]”符号的IE浏览器,这就说明IE已经处于保护状态。去掉保护之后,历史记录连同IE之间安装过的流氓插件、下载的文件都会随之消失。 <br>提醒:<br> Sandboxie本身只能对第一个IE浏览器进程进行保护,不过用桌面上Sandboxie的保护IE的快捷方式来上网,无论打开多少个IE浏览器,都在保护状态下。 <br>(2)、测试安装危险程序 <br> <br> 木马和病毒总是比杀毒软件抢先一步。所以我们在安装程序的时候,即时杀毒软件没有报毒,也存在一定的风险。但使用Sandboxie后,就会将风险降低为零了。 <br> <br>选要安装或解压的不明程序,按鼠标右键,选择“用沙盘运行”,就会以保护的形式来安装或解压该程序。同样,在程序的安装窗口中会发现标题栏上有两个“[#]”符号代表受保护。笔者在安装一个捆绑木马的程序时做了保护措施。恢复系统之后,发现在这期间安装的程序包括木马都消失了,相当的安全。 <br>(3)、保护整个电脑,充当半个“影子系统” <br> <br> Sandboxie还提供整个电脑的保护,在Sandboxie中选择“功能”菜单,然后“选择运行沙盘→Windows 资源管理器”,就会自动弹出有两个“[#]”符号的“我的电脑”窗口。之后对整个电脑进行任意操作,包括格式化分区、删除文件、拷贝文件等都很安全。恢复的方法很简单。在Sandboxie主界面选择“配置 →沙盘设置→设置自动清理选项”,将隔离层中的内容清除即可。 <br><br><br>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值