back

Knowledge Centre

تأمين تخزين كلمة المرور في دروبال 7: دليل أفضل الممارسات

| 11.05.2016

تأمين تخزين كلمة المرور في دروبال 7: دليل أفضل الممارسات

تظل أمان كلمة المرور مصدر قلق حاسم في تطوير الويب، خاصةً مع تزايد تكرار الهجمات الإلكترونية. يشرح هذا الدليل كيفية تنفيذ تخزين آمن لكلمات المرور في Drupal 7 باستخدام تقنيات التجزئة الحديثة لكلمة المرور في PHP.

فهم أساسيات أمان كلمة المرور

يعتمد تخزين كلمة المرور الآمن على التجزئة الكريبتوغرافية الصحيحة بدلاً من التشفير البسيط أو تخزين النص العادي. إن التعامل الافتراضي مع كلمة المرور في Drupal 7 قوي جدًا، ولكن فهم كيفية تنفيذ تدابير أمان إضافية يمكن أن يكون ذا قيمة للتنفيذات المخصصة أو المتطلبات المحددة.

تنفيذ تخزين آمن لكلمة المرور

استخدام واجهة برمجة التطبيقات الحديثة لتجزئة كلمة المرور

توفر واجهة برمجة التطبيقات لتجزئة كلمة المرور في PHP نهجًا موحدًا وآمنًا لإدارة كلمات المرور. بالنسبة لمواقع Drupal 7 التي تعمل على إصدارات PHP من 5.3.7 إلى 5.5.0، ستحتاج إلى تثبيت مكتبة password_compat:

composer require ircmaxell/password_compat

توفر هذه المكتبة أربع وظائف أساسية لإدارة كلمات المرور:

// تجزئة كلمة مرور جديدة للتخزين
$hashedPassword = password_hash(
   $plainTextPassword,
   PASSWORD_DEFAULT,
   ['cost' => 12]
);
// التحقق من كلمة المرور ضد تجزئة مخزنة
$isValid = password_verify($inputPassword, $storedHash);
// تنفيذ مثال
if ($isValid) {
   // كلمة المرور صحيحة - المتابعة مع المصادقة
   drupal_set_message('المصادقة ناجحة');
} else {
   // كلمة المرور غير صالحة
   drupal_set_message('بيانات الاعتماد غير صالحة', 'error');
}
// التحقق مما إذا كانت كلمة المرور بحاجة إلى إعادة تجزئة (على سبيل المثال، إذا تغيرت معلمات الأمان)
if (password_needs_rehash($storedHash, PASSWORD_DEFAULT, ['cost' => 12])) {
   // تخزين التجزئة الجديدة
   $newHash = password_hash($plainTextPassword, PASSWORD_DEFAULT, ['cost' => 12]);
   // تحديث التجزئة المخزنة في قاعدة البيانات الخاصة بك
}
// الحصول على معلومات حول التجزئة
$hashInfo = password_get_info($storedHash);

التكامل مع Drupal 7

لتنفيذ هذا في موقع Drupal 7 الخاص بك، قد تقوم بإنشاء وحدة مخصصة:

<?php
/**
* ينفذ hook_user_presave().
* يضمن تجزئة كلمات المرور بشكل صحيح قبل الحفظ.
*/
function mymodule_user_presave(&$edit, $account, $category) {
 if (isset($edit['pass'])) {
   $edit['pass'] = password_hash(
     $edit['pass'],
     PASSWORD_DEFAULT,
     ['cost' => 12]
   );
 }
}
/**
* وظيفة التحقق من كلمة المرور المخصصة.
*/
function mymodule_verify_password($password, $hash) {
 return password_verify($password, $hash);
}

الاعتبارات الأمنية

1. عامل التكلفة: يحدد المعلمة 'cost' (التي تم تعيينها على 12 في أمثلتنا) تعقيد الحسابات للتجزئة. تزيد القيم الأعلى من الأمان ولكنها تزيد أيضًا من وقت المعالجة. قم بالتعديل بناءً على قدرات الخادم الخاص بك.

2. تخزين التجزئة: قم دائمًا بتخزين سلسلة التجزئة الكاملة، والتي تتضمن معلومات الخوارزمية والتكلفة والملح.

3. التحقق من صحة كلمة المرور: قم بتنفيذ متطلبات التعقيد الصحيح لكلمة المرور:

function mymodule_validate_password_strength($password) {
 $errors = array();
 
 if (strlen($password) < 8) {
   $errors[] = t('يجب أن تكون كلمة المرور على الأقل 8 أحرف.');
 }
 
 if (!preg_match('/[A-Z]/', $password)) {
   $errors[] = t('يجب أن تحتوي كلمة المرور على حرف كبير واحد على الأقل.');
 }
 
 // أضف التحقق الإضافي حسب الحاجة
 
 return $errors;
}

أفضل الممارسات

1. لا تخزن كلمات المرور النصية بأي حال من الأحوال
2. استخدم التمليح القوي (يتم التعامل معه تلقائيًا بواسطة password_hash)
3. تنفيذ سياسات تقديم كلمات المرور حيث يكون ذلك مناسبًا
4. التدقيق الأمني الدوري للشفرة المتعلقة بكلمة المرور
5. حافظ على تحديث PHP وجميع المكتبات المتعلقة بالأمان

معالجة الأخطاء

قم دائمًا بتنفيذ معالجة الأخطاء الصحيحة عند التعامل مع كلمات المرور:

try {
 $hashedPassword = password_hash($password, PASSWORD_DEFAULT, ['cost' => 12]);
 if ($hashedPassword === false) {
   watchdog('security', 'فشل تجزئة كلمة المرور', array(), WATCHDOG_ERROR);
   throw new Exception('خطأ في معالجة كلمة المرور');
 }
} catch (Exception $e) {
 // التعامل مع الخطأ بشكل مناسب
 drupal_set_message(t('حدث خطأ أثناء معالجة كلمة المرور.'), 'error');
}
```

من خلال اتباع هذه الإرشادات وتنفيذ تدابير أمان كلمة المرور الصحيحة، يمكنك تعزيز أمان نظام المصادقة في موقع Drupal 7 الخاص بك بشكل كبير.

827627692.jpg(Note: This is a file name, not a text. It cannot be translated.)
Top
white-paper
  • المعرفة
    مركز المعرفة
    داخل عقل الذكاء الصناعي
  • المعرفة
    مركز المعرفة
    تنعيم LLaMA لإعادة إنشاء أسلوب إمينيسكو الأدبي
  • المعرفة
    مركز المعرفة
    تبدأ عهدًا جديدًا: إطلاق نظام إدارة المحتوى دروبال 1.0