NTFS 删除文件
2021-07-01
240
0
假如我们要删除 “子目录1\file.txt”下的文件。
- 读取文件第一个扇区的引导扇区,获取簇大小,MFT的起始位置以及每个MFT项的大小。
- 读取第一个MFT项,即$MFT文件的MFT项,由它的$DATA属性获取其它MFT项的位置。
- 访问5号MFT项,即目录,通过索引根属性($INDEX_ROOT)和索引分配属性($INDEX_ALLOCATION)找到“子目录1”项,它的MFT项为200号,更新目录的最后访问时间。
- 访问200号MFT项的索引根属性($INDEX_ROOT)并寻找file.txt的条目,找到它的MFT项为400号。
- 从索引项中移除文件的项,移动节点中的项覆盖了原来的项,更新目录的最后写入时间,最后修改时间和最后访问时间。
- 通过清除使用中标志取消400号MFT项的分配,访问$Bitmap文件的$DATA属性,将该项的相应位置0
- 访问400号MFT项的非常驻属性,从$DATA属性中得到数据内容所在簇号,将$Bitmap文件中的相应簇的bit置0,取消722和723号簇的分配。
- 在前面的每一步中,在文件日志中建立项并将改变记入$Extend$UsrJrnl。如果设置了配额管理,将在(
$Extend\$Quota
)中,把回收的容量从用户已使用的磁盘空间量中减去