- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的问题有点独特。我目前正在为我的计算机取证课做一个项目。该项目旨在向调查人员隐藏磁盘数据。应该实现的方法是将“干净”文件的字节写入“坏”文件。覆盖后,“坏”文件将被删除。
这个概念听起来很简单,但我和我的伙伴观察到的东西很有趣。如果我们在 python 脚本中打开一个文件,我们可以很容易地覆盖磁盘上与该文件关联的内存(使用 dd 验证)。我们还可以从脚本内部轻松删除文件。但是,先写后删除不会导致实际发生写入,只会删除文件。
从操作系统优化的角度来看,这是有道理的。从那时起,我们认为如果将写入和删除分成两个单独的脚本,并由第三方控制,可能会奏效。然而,似乎即使我们将脚本作为另一个脚本的子进程运行,也会发生同样的事情。我们已尝试使用 bash 脚本而不是纯 python 进行删除过程,但仍然没有任何效果。
这个项目本来应该是一堆像这样的小反取证工具,但这个特别的工具因为这个问题引起了我们的全部注意。有没有人知道为什么会发生这种情况以及我们可以做些什么来推进?
我们知道这可以在 C 等语言中实现,但我们想使用 Python 来解决这个问题,因为它提供了一些有趣的限制。
---编辑---这是我们 Controller 的一个片段,它调用带有相关参数的“ghost.py”。
ghost.py 将编辑后的文件名/路径打印到标准输出。
相关代码如下:
proc = subprocess.Popen(['python', 'ghost.py', '-c', 'good.txt', '-d','/mnt/evil.txt'], stdout=subprocess.PIPE,)
files = proc.communicate()
for i in files:
if i != None and i != "\n":
os.system("./del.sh " + i)
最佳答案
使用子流程不会改变您设计的任何有趣方面,所以不要使用它们。您可能需要 os.fsync()
。试试这个模式:
myfile.write('all of my good data')
myfile.flush()
os.fsync(myfile.fileno())
myfile.close()
os.remove(myfile)
关于python - 操作系统如何处理 python 和 python 脚本的子进程......?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29979726/
需要帮助将这些给定的数字打印成星号,但我是编程新手;我该怎么做? #include int main(void) { int a[5]={20,1,5,15,12}; int i=0
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我不知道制服在内存中是如何表示的。 制服似乎会占用宝贵的寄存器空间,但它们最终会传入/通过/传出到全局内存中,对吗? 制服不用时情况会发生变化吗?编译器可以将它们优化掉吗?--在这种情况下,我已经将无
我正在尝试在名为“timeclock”的模型上记录“time_in”和“time_out”记录。这是我想做但无法开始工作的事情! 检查最后一个时钟条目,看看它是否同时填充了“time_in”和“tim
我想听听您如何解决这种编程任务!?每种类型(OPER = 1 类型)对应一种特定的信息。 这只是大约 10 个具有相同结构的规范之一。首选创建这些“转换器”(协议(protocol))的通用方法。 最
我正在使用 Rest API(NodeJS、Express)和 PostgreSQL 制作 React-Native 应用。 在我的本地机器上托管时一切正常。当 API 托管在我的机器上并且 Post
我是一名优秀的程序员,十分优秀!