Category Archives: shred

حذف ملف بشكل تام وآمن على لينكس

تحدثتُ في تدوينة سابقة عن برنامج Photorec لاستعادة البيانات المحذوفة حيثُ شرحتُ في تلك التدوينة مبدأ عمل البرنامج وماذا يحدث عند حذف ملف أو مجلد بالطريقة المعهودة الموجودة بشكل افتراضي في كل نظم التشغيل.

استكمالا لذلك الحديث أقدم بين يديكم اليوم طريقتين لحذف ملف بشكل نهائي من على القرص الصلب وبذلك يكون من شبه المستحيل استعادته.

تحديث بتاريخ 10 سبتمبر لإضافة طريقة  التعامل مع المجلدات عبر الأمر shred

الطريقة الأولى تعتمد على إضافة لمدير الملفات Nautilus. أما الثانية فتعتمد على حزمة تأتي بشكل افتراضي مع أغلب توزيعات لينكس. مبدأ العمل في الحالتين هو كتابة معطيات عشوائية مكان الملف المُراد حذفه.

حذف الملفات مع إضافة nautilus-wipe

عند تثبيت هذه الإضافة فإنها ستُدرج في القائمة الظرفية التي تظهر عند النقر بزر الفأرة

الأيمن على اسم الملف أو المجلد. للتثبيت على أوبنتو ننفذ الأمر التالي

sudo apt-get install nautilus-wipe

بعد التثبيت سيظهر الخياران التاليان في القائمة الظرفية عند النقر بالزر الأيمن على اسم ملف أو مجلد.

nautilus-wipe

nautilus-wipe

  • الخيار الأول wipe والذي يحذف بشكل آمن الملفات المُحددة. يمكن التحكم في عدد مرات إعادة الكتابة عبر الخيار Number of passes. الإعداد الافتراضي هو مرتان. وهو إعداد كاف بنظري فالمبالغة في مرات إعادة الكتابة قد تضر بالقرص الصلب على المدى الطويل.

    تأكيد الحذف وخيارات wipe

    تأكيد الحذف وخيارات wipe

  • الخيار الثاني wipe available disk space يسمح بحذف الملفات التي سبق محوها بطريقة غير آمنة من على تجزئة أو قرص صلب. هذه العملية قد تأخذ بعض الوقت.

حذف الملفات بأداة shred عبر سطر الأوامر

نستخدم أمر shred لهذا الغرض ويعمل بنفس مبدأ عمل الإضافة السابقة وذلك بالشكل التالي

shred -n 2 -z -u file

حيثُ

  • الخيار n- يُمكن من تحديد عدد مرات إعادة الكتابة. (2 في مثالنا هذا). إذا لم يحدد هذا الخيار فإن الأداة ستعيد الكتابة 3 مرات (الإعداد الافتراضي)
  • الخيار z- لكتابة أصفار مكان بيانات الملفات
  • الخيار u- لحذف الملف
  • file مسار الملف المراد حذفه

ما تقوم به shred هنا هو كتابة أصفار مكان بيانات الملف ثم حذفه (وهذا هو دور الخيار u-). في حالة حاول أحدهم استعادة الملف فإنه إن نجح سيحصل على ملف مليئ بالأصفار فقط.

يمكن إجراء التجربة التالية لفهم آلية العمل. أنشئ ملفا وليكن اسمه test.txt واكتب فيه شيئا ما للتجربة ثم أغلقه واحفظه. افتح الطرفية ثم تنقل إلى مسار الملف test.txt ونفذ الأمر

shred -n 2 -z test.txt

لاحظ أني لم أضف خيار u- . جرب فتح الملف مرة أخرى بمحرر نصوص. جرب الأمر مرة أخرى ولكن بإضافة خيار u- ثم ابحث عن الملف، لن تجدَه 🙂 .

حذف المجلدات بواسطة shred

الأمر shred لا يتعامل مع المجلدات،
لحذف مجلد يمكن تنفيذ الطريقة التالية، من خطوتين.
للشرح سأفترض وجود مجلد testA بداخله ملف testA1 ومجلد آخر testB وبداخل المجلد الأخير يوجد ملفان testB1 و testB2


testA
-- testA1
-- testB
---- testB1
---- testB2

نريد حذف testA بكل محتوياته بشكل آمن.

  • الخطوة الأولى حذف جميع الملفات (تبقى فقط المجلدات)

نفتح المجلد testA ثم ننفذ الأمر التالي


find -type f -execdir shred -n 2 -z -u '{}' \;

الذي سيبحث عن جميع الملفات الموجودة في المجلد الحالي، أي testA في مثالنا، ومجلداته الفرعية. ثم يطبق الأمر shred -n 2 -z -u على كل ملف من تلك الملفات.

يمكن سرد محتويات المجلد testA أو testB وستلاحظ أنه لا توجد بها ملفات.

  • الخطوة الثانية ستكون حذف المجلد testA ومجلداته الفرعية عبر الأمر (تأكد من الخروج من المجلد testA قبل تنفيذ الأمر)

rm -rf /pat/to/testA

حيث /pat/to/testA هو المسار نحو المجلد testA .

إلى الملتقى.

رابط مختصر للمشاركة مع أصدقائك عبر شبكات التواصل الاجتماعي http://wp.me/p1vJeS-fV

للحصول على آخر الإضافات مباشرة بعد نشرها يُرجى الاشتراك في تغذيات RSS.

مصادر

http://www.crowd42.info/supprimer-fichier-definitivement-ordinateur-debian-gnulinux-ubuntu

http://www.solver.io/wp/2012/11/06/linux-how-to-recursively-shred-a-directory/