روشهای پاکسازی دادهها در استاندارد US DoD 5220 22 M
استاندارد US DoD 5220.22-M که به آن "مقررات امنیتی ملی صنایع دفاعی" نیز گفته میشود، یک روش رسمی برای حذف دادهها از دستگاههای ذخیرهسازی داده است. این استا...
روشهای پاکسازی دادهها در استاندارد US DoD 5220.22-M
استاندارد US DoD 5220.22-M که به آن "مقررات امنیتی ملی صنایع دفاعی" نیز گفته میشود، یک روش رسمی برای حذف دادهها از دستگاههای ذخیرهسازی داده است. این استاندارد توسط وزارت دفاع ایالات متحده (Department of Defense یا DoD) تدوین شده و برای اطمینان از حذف کامل و غیرقابل بازیابی دادهها از هارد دیسکها و سایر دستگاههای ذخیرهسازی مورد استفاده قرار میگیرد.
روشهای پاکسازی دادهها در استاندارد US DoD 5220.22-M
این استاندارد چندین روش مختلف برای پاکسازی دادهها ارائه میدهد که در زیر به توضیح برخی از این روشها پرداخته شده است:
-
روش سهپاسه (3-Pass Overwrite):
- پاس اول: نوشتن یک کاراکتر ثابت (مثلاً صفر).
- پاس دوم: نوشتن کاراکتر مکمل (مثلاً یک).
- پاس سوم: نوشتن یک کاراکتر تصادفی.
-
روش هفتپاسه (7-Pass Overwrite):
- پاس اول: نوشتن کاراکتر ثابت (مثلاً صفر).
- پاس دوم: نوشتن کاراکتر ثابت دیگر (مثلاً یک).
- پاس سوم: نوشتن یک کاراکتر تصادفی.
- پاس چهارم: نوشتن کاراکتر ثابت (مثلاً صفر).
- پاس پنجم: نوشتن کاراکتر ثابت دیگر (مثلاً یک).
- پاس ششم: نوشتن یک کاراکتر تصادفی.
- پاس هفتم: نوشتن یک کاراکتر تصادفی.
-
روش N-Pass Overwrite:
- نوشتن دادههای تصادفی بر روی دادههای موجود به تعداد پاسهای مشخص شده.
اهمیت استاندارد US DoD 5220.22-M
این استاندارد بهویژه در محیطهای نظامی و امنیتی بسیار اهمیت دارد، زیرا اطمینان حاصل میکند که اطلاعات حساس و محرمانه به هیچ وجه قابل بازیابی نیستند. استفاده از این روشها باعث میشود تا اطلاعات حذف شده با روشهای پیشرفته بازیابی داده قابل بازیابی نباشد.
موارد استفاده
استاندارد US DoD 5220.22-M به طور گستردهای در سازمانهای دولتی، نظامی، و همچنین شرکتهای خصوصی که با اطلاعات حساس سر و کار دارند، استفاده میشود. این استاندارد یکی از استانداردهای مورد اعتماد در زمینه امنیت داده و حذف امن اطلاعات است.
استفاده از این استاندارد میتواند تضمین کند که دادههای حساس شما به طور کامل و غیرقابل برگشت از دستگاههای ذخیرهسازی حذف شوند.
نمونه کد پیادهسازی US DoD 5220.22-M در سیشارپ
برای پیادهسازی استاندارد US DoD 5220.22-M با استفاده از زبان برنامهنویسی سیشارپ، میتوانیم از توابعی برای نوشتن دادههای مختلف بر روی فایلهای موجود استفاده کنیم. در زیر مثالی از یک برنامه سیشارپ ارائه شده است که روش سهپاسه (3-Pass Overwrite) را پیادهسازی میکند:
using System;
using System.IO;
using System.Security.Cryptography;
// Programmer : Ebrahim Shafiei (EbraSha)
class Program
{
static void Main(string[] args)
{
string filePath = "yourfile.txt";
OverwriteFileDoD5220_22M(filePath);
}
static void OverwriteFileDoD5220_22M(string filePath)
{
if (!File.Exists(filePath))
{
Console.WriteLine("File does not exist.");
return;
}
long fileSize = new FileInfo(filePath).Length;
// Pass 1: Overwrite with 0x00
OverwriteFile(filePath, fileSize, 0x00);
// Pass 2: Overwrite with 0xFF
OverwriteFile(filePath, fileSize, 0xFF);
// Pass 3: Overwrite with random bytes
OverwriteFileWithRandom(filePath, fileSize);
// Optionally, delete the file after overwriting
// File.Delete(filePath);
Console.WriteLine("File overwritten using DoD 5220.22-M (3-Pass) standard.");
}
static void OverwriteFile(string filePath, long fileSize, byte overwriteByte)
{
byte[] data = new byte[fileSize];
for (long i = 0; i < fileSize; i++)
{
data[i] = overwriteByte;
}
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Write))
{
fs.Write(data, 0, data.Length);
}
}
static void OverwriteFileWithRandom(string filePath, long fileSize)
{
byte[] data = new byte[fileSize];
using (RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider())
{
rng.GetBytes(data);
}
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Write))
{
fs.Write(data, 0, data.Length);
}
}
}
توضیحات کد
- پاس اول: در روش
OverwriteFile
، فایل را با بایتهای0x00
بازنویسی میکنیم. - پاس دوم: در همان روش، فایل را با بایتهای
0xFF
بازنویسی میکنیم. - پاس سوم: در روش
OverwriteFileWithRandom
، فایل را با بایتهای تصادفی بازنویسی میکنیم.
این کد سهپاسه ساده از استاندارد US DoD 5220.22-M را پیادهسازی میکند. میتوانید این کد را بهصورت کتابخانهای گسترش داده و یا روشهای بیشتری را اضافه کنید. اگر نیاز به تعداد پاسهای بیشتر داشتید، میتوانید به راحتی این روشها را در کد خود اضافه کنید.
نمونه کد پیادهسازی روش 7-پاسه در سیشارپ
برای پیادهسازی روش 7-پاسه (7-Pass Overwrite) بر اساس استاندارد US DoD 5220.22-M، میتوانیم کد را به گونهای تغییر دهیم که به جای سه پاس، هفت پاس انجام شود. در این روش، فایل به ترتیب با بایتهای ثابت و بایتهای تصادفی بازنویسی میشود.
using System;
using System.IO;
using System.Security.Cryptography;
// Programmer : Ebrahim Shafiei (EbraSha)
class Program
{
static void Main(string[] args)
{
string filePath = "yourfile.txt";
OverwriteFileDoD5220_22M(filePath);
}
static void OverwriteFileDoD5220_22M(string filePath)
{
if (!File.Exists(filePath))
{
Console.WriteLine("File does not exist.");
return;
}
long fileSize = new FileInfo(filePath).Length;
// Pass 1: Overwrite with 0x00
OverwriteFile(filePath, fileSize, 0x00);
// Pass 2: Overwrite with 0xFF
OverwriteFile(filePath, fileSize, 0xFF);
// Pass 3: Overwrite with random bytes
OverwriteFileWithRandom(filePath, fileSize);
// Pass 4: Overwrite with 0x00
OverwriteFile(filePath, fileSize, 0x00);
// Pass 5: Overwrite with 0xFF
OverwriteFile(filePath, fileSize, 0xFF);
// Pass 6: Overwrite with random bytes
OverwriteFileWithRandom(filePath, fileSize);
// Pass 7: Overwrite with random bytes
OverwriteFileWithRandom(filePath, fileSize);
// Optionally, delete the file after overwriting
// File.Delete(filePath);
Console.WriteLine("File overwritten using DoD 5220.22-M (7-Pass) standard.");
}
static void OverwriteFile(string filePath, long fileSize, byte overwriteByte)
{
byte[] data = new byte[fileSize];
for (long i = 0; i < fileSize; i++)
{
data[i] = overwriteByte;
}
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Write))
{
fs.Write(data, 0, data.Length);
}
}
static void OverwriteFileWithRandom(string filePath, long fileSize)
{
byte[] data = new byte[fileSize];
using (RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider())
{
rng.GetBytes(data);
}
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Write))
{
fs.Write(data, 0, data.Length);
}
}
}
توضیحات کد
- پاس اول: بازنویسی فایل با بایتهای
0x00
. - پاس دوم: بازنویسی فایل با بایتهای
0xFF
. - پاس سوم: بازنویسی فایل با بایتهای تصادفی.
- پاس چهارم: بازنویسی فایل با بایتهای
0x00
. - پاس پنجم: بازنویسی فایل با بایتهای
0xFF
. - پاس ششم: بازنویسی فایل با بایتهای تصادفی.
- پاس هفتم: بازنویسی فایل با بایتهای تصادفی.
این کد فایل را به صورت 7-پاسه بازنویسی میکند تا اطمینان حاصل شود که دادههای قبلی به طور کامل حذف شده و قابل بازیابی نیستند.
نمونه کد پیادهسازی پاکسازی فضای خالی یک درایو با استاندارد US DoD 5220.22-M در سیشارپ
یکی از موارد بسیار مهم حذف فضای خالی برای زمانی است که شما می خواهید فایل هایی که به صورت عادی حذف کرده اید باز رکاوری نشود ، اگر بخواهید این کار را با استفاده از زبان برنامهنویسی سیشارپ پیادهسازی کنید، میتوانید به شکل زیر عمل کنید:
مراحل پیادهسازی:
- شناسایی فضای خالی: باید فضای خالی موجود در دیسک را شناسایی کرده و بر روی آن بنویسید. این کار معمولاً بهوسیلهی ایجاد فایلهای موقتی تا پر شدن کامل فضای خالی انجام میشود.
- بازنویسی دادهها: بازنویسی فضای خالی با استفاده از روشهای مختلف مانند
0x00
،0xFF
و دادههای تصادفی.
using System;
using System.IO;
using System.Security.Cryptography;
// Programmer : Ebrahim Shafiei (EbraSha)
class Program
{
static void Main(string[] args)
{
string driveLetter = "C"; // Change to the desired drive letter
WipeFreeSpace(driveLetter);
}
static void WipeFreeSpace(string driveLetter)
{
DriveInfo drive = new DriveInfo(driveLetter);
if (!drive.IsReady || drive.DriveType != DriveType.Fixed)
{
Console.WriteLine("Drive is not ready or is not a fixed drive.");
return;
}
long freeSpace = drive.TotalFreeSpace;
string tempFilePath = Path.Combine(drive.RootDirectory.FullName, "tempWipeFile.dat");
try
{
// Pass 1: Overwrite with 0x00
OverwriteFile(tempFilePath, freeSpace, 0x00);
// Pass 2: Overwrite with 0xFF
OverwriteFile(tempFilePath, freeSpace, 0xFF);
// Pass 3: Overwrite with random bytes
OverwriteFileWithRandom(tempFilePath, freeSpace);
// Pass 4: Overwrite with 0x00
OverwriteFile(tempFilePath, freeSpace, 0x00);
// Pass 5: Overwrite with 0xFF
OverwriteFile(tempFilePath, freeSpace, 0xFF);
// Pass 6: Overwrite with random bytes
OverwriteFileWithRandom(tempFilePath, freeSpace);
// Pass 7: Overwrite with random bytes
OverwriteFileWithRandom(tempFilePath, freeSpace);
// Delete the temporary file
File.Delete(tempFilePath);
Console.WriteLine("Free space wiped using DoD 5220.22-M (7-Pass) standard.");
}
catch (Exception ex)
{
Console.WriteLine($"Error: {ex.Message}");
}
}
static void OverwriteFile(string filePath, long fileSize, byte overwriteByte)
{
using (FileStream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write))
{
byte[] data = new byte[1024 * 1024]; // 1MB buffer
for (int i = 0; i < data.Length; i++)
{
data[i] = overwriteByte;
}
long totalWritten = 0;
while (totalWritten < fileSize)
{
long remaining = fileSize - totalWritten;
int toWrite = remaining < data.Length ? (int)remaining : data.Length;
fs.Write(data, 0, toWrite);
totalWritten += toWrite;
}
}
}
static void OverwriteFileWithRandom(string filePath, long fileSize)
{
using (FileStream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write))
{
byte[] data = new byte[1024 * 1024]; // 1MB buffer
using (RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider())
{
long totalWritten = 0;
while (totalWritten < fileSize)
{
rng.GetBytes(data);
long remaining = fileSize - totalWritten;
int toWrite = remaining < data.Length ? (int)remaining : data.Length;
fs.Write(data, 0, toWrite);
totalWritten += toWrite;
}
}
}
}
}
توضیحات کد
- شناسایی فضای خالی: از کلاس
DriveInfo
برای شناسایی فضای خالی استفاده میشود. - ایجاد فایل موقتی: فایل موقتی در ریشه درایو ایجاد میشود و با استفاده از بایتهای
0x00
،0xFF
و دادههای تصادفی پر میشود. - حذف فایل موقتی: بعد از بازنویسی، فایل موقتی حذف میشود تا فضای خالی پاکسازی شود.
این روش به شما اجازه میدهد تا فضای خالی دیسک را بهصورت امن و غیر قابل بازیابی پاکسازی کنید. البته در نظر داشته باشید که استفاده از این روش نیاز به فضای خالی کافی در دیسک دارد و ممکن است زمانبر باشد.
دیدگاه های مربوط به این مقاله (برای ارسال دیدگاه در سایت حتما باید عضو باشید و پروفایل کاربری شما تکمیل شده باشد)