Python 取证 Python 成像库
从可用资源中提取有价值的信息是数字取证的重要组成部分。获取所有可用信息对于调查过程至关重要,因为它有助于检索适当的证据。
包含数据的资源可以是简单的数据结构,例如数据库,也可以是复杂的数据结构,例如 JPEG 图像。使用简单的桌面工具可以轻松访问简单的数据结构,而从复杂的数据结构中提取信息则需要复杂的编程工具。
Python 图像库
Python 图像库 (PIL) 为你的 Python 解释器添加了图像处理功能。该库支持多种文件格式,并提供强大的图像处理和图形功能。你可以从以下位置下载 PIL 的源文件: http://www.pythonware.com/products/pil/
下图显示了在 PIL 中从图像(复杂数据结构)中提取数据的完整流程图。
例子
现在,让我们通过一个编程示例来了解它的实际工作原理。
步骤 1 :假设我们有下面这张图片,我们需要从中提取信息。
步骤 2 :当我们使用PIL打开这张图片时,它会首先记下提取证据所需的必要点,其中包括各种像素值。下面是打开图像并记录其像素值的代码:
from PIL import Image im = Image.open('Capture.jpeg', 'r') pix_val = list(im.getdata()) pix_val_flat = [x for sets in pix_val for x in sets] print pix_val_flat
步骤 3 : 我们的代码在提取图像的像素值后会产生如下输出。
传递的输出代表 RGB 组合的像素值,这可以更好地了解需要哪些数据来作为证据。获取的数据以数组的形式表示。