ModSecurity و OWASP على CentOS 6 و Apache 2

ModSecurity هو جدار حماية طبقة تطبيق ويب مصمم للعمل مع IIS و Apache2 و Nginx. إنه برنامج مجاني مفتوح المصدر تم إصداره بموجب ترخيص Apache 2.0. يساعد ModSecurity على تأمين خادم الويب الخاص بك عن طريق مراقبة وتحليل حركة المرور على موقع الويب الخاص بك. وهي تفعل ذلك في الوقت الفعلي لاكتشاف الهجمات من أكثر مآثر الاستغلال المعروفة وحظرها باستخدام التعبيرات العادية. من تلقاء نفسه ، يوفر ModSecurity حماية محدودة ويعتمد على مجموعات القواعد لزيادة الحماية إلى أقصى حد.

مجموعة القواعد الأساسية (CRS) لمشروع أمان تطبيق الويب المفتوح (OWASP) هي مجموعة من القواعد العامة للكشف عن الهجمات التي توفر مستوى أساسيًا من الحماية لأي تطبيق ويب. مجموعة القواعد مجانية ومفتوحة المصدر وترعاها حاليًا Spider Labs.

يوفر OWASP CRS:

  • حماية HTTP - اكتشاف انتهاكات بروتوكول HTTP وسياسة استخدام محددة محليًا.
  • عمليات البحث في القائمة السوداء في الوقت الفعلي - تستخدم سمعة عنوان IP للطرف الثالث.
  • حماية HTTP من رفض الخدمة - الدفاع ضد فيضان HTTP وهجمات HTTP DoS البطيئة.
  • الحماية الشائعة من هجمات الويب - اكتشاف الهجمات الأمنية الشائعة على تطبيقات الويب.
  • كشف الأتمتة - الكشف عن الروبوتات والزواحف والماسحات الضوئية وغيرها من الأنشطة الخبيثة على السطح.
  • التكامل مع AV Scanning لتحميلات الملفات - يكتشف الملفات الضارة التي تم تحميلها من خلال تطبيق الويب.
  • تتبع البيانات الحساسة - يتتبع استخدام بطاقة الائتمان ويمنع التسرب.
  • حماية طروادة - يكتشف أحصنة طروادة.
  • تحديد عيوب التطبيق - تنبيهات بشأن التكوينات الخاطئة للتطبيق.
  • اكتشاف الأخطاء وإخفاؤها - إخفاء رسائل الخطأ المرسلة من قبل الخادم.

التركيب

يوضح لك هذا الدليل كيفية تثبيت مجموعة قواعد ModSecurity و OWASP على CentOS 6 الذي يقوم بتشغيل Apache 2.

أولاً ، تحتاج إلى التأكد من تحديث نظامك.

 yum -y update

إذا لم تقم بتثبيت Apache 2 ، فقم بتثبيته الآن.

 yum -y install httpd

تحتاج الآن إلى تثبيت بعض التبعيات لكي يعمل ModSecurity. بناءً على تكوين الخادم لديك ، قد تكون بعض هذه الحزم أو جميعها مثبتة بالفعل. ستقوم Yum بتثبيت الحزم التي لا تمتلكها وإبلاغك إذا كانت أي من الحزم مثبتة بالفعل.

 yum -y install httpd-devel git gcc make libxml2 pcre-devel libxml2-devel curl-devel

تغيير الدليل وتنزيل شفرة المصدر من موقع ModSecuity على الويب. الإصدار الثابت الحالي هو 2.8.

 cd /opt/
 wget https://www.modsecurity.org/tarball/2.8.0/modsecurity-2.8.0.tar.gz

قم باستخراج الحزمة وتغييرها إلى الدليل الخاص بها.

 tar xzfv modsecurity-2.8.0.tar.gz 
 cd modsecurity-2.8.0

تكوين وتجميع التعليمات البرمجية المصدر.

 ./configure
 make
 make install

انسخ ملف ModSecurity الافتراضي وملف تعيين unicode إلى دليل Apache.

 cp modsecurity.conf-recommended /etc/httpd/conf.d/modsecurity.conf
 cp unicode.mapping /etc/httpd/conf.d/

تكوين أباتشي لاستخدام ModSecurity. هناك طريقتان للقيام بذلك.

 echo LoadModule security2_module modules/mod_security2.so >> /etc/httpd/conf/httpd.conf

... أو استخدم محرر نصوص مثل nano:

 nano /etc/httpd/conf/httpd.conf

في الجزء السفلي من هذا الملف ، على سطر منفصل ، أضف هذا:

 LoadModule security2_module modules/mod_security2.so

يمكنك الآن بدء تشغيل Apache وتكوينه ليبدأ عند التمهيد.

 service httpd start
 chkconfig httpd on

إذا كان لديك Apache مثبتًا قبل استخدام هذا الدليل ، فأنت بحاجة فقط إلى إعادة تشغيله.

 service httpd restart

يمكنك الآن تنزيل مجموعة القواعد الأساسية لـ OWASP.

 cd /etc/httpd
 git clone https://github.com/SpiderLabs/owasp-modsecurity-crs.git

الآن تكوين مجموعة قواعد OWASP.

 cd modsecurity-crs
 cp modsecurity_crs_10_setup.conf.example modsecurity_crs_10_config.conf

بعد ذلك ، تحتاج إلى إضافة مجموعة القواعد إلى تكوين Apache. مرة أخرى يمكننا القيام بذلك بطريقتين.

 echo Include modsecurity-crs/modsecurity_crs_10_config.conf >> /etc/httpd/conf/httpd.conf
 echo Include modsecurity-crs/base_rules/*.conf >> /etc/httpd/conf/httpd.conf

... أو مع محرر نصوص:

 nano /etc/httpd/conf/httpd.conf

في الجزء السفلي من الملف على أسطر منفصلة ، أضف هذا:

 Include modsecurity-crs/modsecurity_crs_10_config.conf
 Include modsecurity-crs/base_rules/*.conf

أعد تشغيل Apache الآن.

 service httpd restart

أخيرًا ، احذف ملفات التثبيت.

 yum erase /opt/modsecurity-2.8.0
 yum erase /opt/modsecurity-2.8.0.tar.gz

باستخدام ModSecurity

بشكل افتراضي ، يتم تشغيل ModSecurity في وضع الكشف فقط ، مما يعني أنه سيتم تسجيل جميع فواصل القواعد ولكن لن يتخذ أي إجراء. يوصى بهذا لعمليات التثبيت الجديدة حتى تتمكن من مشاهدة الأحداث التي تم إنشاؤها في سجل أخطاء Apache. بعد مراجعة السجل ، يمكنك تحديد ما إذا كان يجب إجراء أي تعديل على مجموعة القواعد أو تعطيل القاعدة (انظر أدناه) قبل الانتقال إلى وضع الحماية.

لعرض سجل أخطاء Apache:

 cat /var/log/httpd/error_log

ينقسم سطر ModSecurity في سجل أخطاء Apache إلى تسعة عناصر. يوفر كل عنصر معلومات حول سبب تشغيل الحدث.

  • يخبر الجزء الأول عن ملف القاعدة الذي تسبب في هذا الحدث.
  • يوضح الجزء الثاني أي سطر في ملف القاعدة تبدأ القاعدة عليه.
  • يخبرك العنصر الثالث بالقاعدة التي تم تشغيلها.
  • يخبرك العنصر الرابع بمراجعة القاعدة.
  • يحتوي العنصر الخامس على بيانات خاصة لأغراض التصحيح.
  • يحدد العنصر السادس شدة التسجيل لشدة هذا الحدث.
  • يصف القسم السابع الإجراء الذي حدث وفي أي مرحلة حدث.

لاحظ أن بعض العناصر قد تكون غائبة اعتمادًا على تكوين الخادم الخاص بك.

لتغيير ModSecurity إلى وضع الحماية ، افتح ملف conf في محرر نصوص:

 nano /etc/httpd/conf.d/modsecurity.conf

... والتغيير:

 SecRuleEngine DetectionOnly

إلى:

 SecRuleEngine On

إذا واجهت أي كتل أثناء تشغيل ModSecurity ، فأنت بحاجة إلى تحديد القاعدة في سجل أخطاء HTTP. يتيح لك الأمر "tail" مشاهدة السجلات في الوقت الفعلي:

 tail -f /var/log/httpd/error_log

كرر الإجراء الذي تسبب في الكتلة أثناء مشاهدة السجل.

تعديل مجموعة القواعد / تعطيل معرف القاعدة

تعديل مجموعة قواعد خارج نطاق هذا البرنامج التعليمي.

لتعطيل قاعدة معينة ، يمكنك تحديد معرف القاعدة الموجود في العنصر الثالث (على سبيل المثال [id = 200000]) ثم تعطيله في ملف تكوين Apache:

 nano /etc/httpd/conf/httpd.conf

... عن طريق إضافة ما يلي إلى أسفل الملف بمعرف القاعدة:

<IfModule mod_security2.c>
SecRuleRemoveById 200000
</IfModule>

إذا وجدت أن ModSecurity يحظر جميع الإجراءات على موقعك (مواقعك) ، فمن المحتمل أن تكون "مجموعة القواعد الأساسية" في وضع "الاكتفاء الذاتي". تحتاج إلى تغيير هذا إلى "الكشف التعاوني" ، الذي يكتشف ويحظر الحالات الشاذة فقط. في الوقت نفسه ، يمكنك إلقاء نظرة على خيارات "الاكتفاء الذاتي" وتغييرها إذا كنت ترغب في ذلك.

 nano /etc/httpd/modsecurity-crs/modsecurity_crs_10_config.conf

تغيير "الكشف" إلى "مكتفية ذاتيا".

يمكنك أيضًا تكوين ModSecurity للسماح بعنوان IP الخاص بك من خلال جدار حماية تطبيق الويب (WAF) بدون تسجيل:

 SecRule REMOTE_ADDR "@ipMatch xxx.xxx.xxx.xxx" phase:1,nolog,allow,ctl:ruleEngine=Off

... أو مع تسجيل:

 SecRule REMOTE_ADDR "@ipMatch xxx.xxx.xxx.xxx" phase:1,nolog,allow,ctl:ruleEngine=DetectionOnly


Leave a Comment

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت CMS أكتوبر على CentOS 7

كيفية تثبيت CMS أكتوبر على CentOS 7

أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة

كيفية تثبيت المجدول المحجوز على CentOS 7

كيفية تثبيت المجدول المحجوز على CentOS 7

استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th

تثبيت Netdata على CentOS 7

تثبيت Netdata على CentOS 7

استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:

كيفية تثبيت DreamFactory Open Source على CentOS 7

كيفية تثبيت DreamFactory Open Source على CentOS 7

DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي

كيفية تثبيت خادم Starbound على CentOS 7

كيفية تثبيت خادم Starbound على CentOS 7

استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Django على CentOS 7

كيفية تثبيت Django على CentOS 7

Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها

تثبيت Revive Adserver على CentOS 7

تثبيت Revive Adserver على CentOS 7

Revive Adserver هو نظام عرض إعلانات مجاني ومفتوح المصدر يمكن استخدامه لإدارة الإعلانات على مواقع الويب و / أو التطبيقات و / أو مشغلات الفيديو. في هذه المقالة ،

قم بتثبيت Elgg على CentOS 7

قم بتثبيت Elgg على CentOS 7

استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po

نشر Kubernetes مع Kubeadm على CentOS 7

نشر Kubernetes مع Kubeadm على CentOS 7

نظرة عامة تهدف هذه المقالة إلى مساعدتك في إنشاء مجموعة Kubernetes وتشغيلها باستخدام kubeadm في لمح البصر. سيقوم هذا الدليل بنشر خادمين في

قم بإعداد Sails.js للتطوير على CentOS 7

قم بإعداد Sails.js للتطوير على CentOS 7

استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver

كيفية تجميع Nginx من المصدر على CentOS 7

كيفية تجميع Nginx من المصدر على CentOS 7

استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت

كيفية تثبيت dotCMS على CentOS 7

كيفية تثبيت dotCMS على CentOS 7

استخدام نظام مختلف؟ dotCMS هو نظام إدارة محتوى من فئة مفتوحة المصدر مفتوح بلغة جافا. أنه يحتوي تقريبا على كل ميزة مطلوبة ر

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

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

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد