ModSecurance و OWASP در CentOS 6 و Apache 2

ModSecurance یک فایروال لایه ای با برنامه وب است که برای همکاری با IIS ، Apache2 و Nginx طراحی شده است. این نرم افزار رایگان با منبع آزاد است که تحت مجوز Apache 2.0 منتشر شده است. ModSecurance با نظارت و تجزیه و تحلیل ترافیک وب سایت شما به امنیت سرور وب کمک می کند. این کار را در زمان واقعی انجام می دهد تا حملات بیشترین بهره برداری های شناخته شده را با استفاده از عبارات منظم شناسایی و مسدود کند. به تنهایی ، ModSecurance محافظت محدودی را به شما می دهد و به حداکثر حمایت از قوانین کمک می کند.

Open Security Project Project Security (OWASP) Core Rule Set (CRS) مجموعه ای از قواعد تشخیص عمومی حمله است که سطح پایه ای از محافظت را برای هر برنامه وب فراهم می کند. این قانون رایگان ، متن باز و در حال حاضر توسط اسپایدر لابراتوار پشتیبانی می شود.

OWASP CRS فراهم می کند:

  • حفاظت HTTP - تشخیص نقض پروتکل HTTP و یک خط مشی استفاده محلی تعریف شده.
  • جستجوی لیست سیاه بلادرنگ - از اعتبار IP IP 3rd استفاده می کند.
  • انکار HTTP از خدمات حفاظت - دفاع در برابر طغیان HTTP و حملات آهسته HTTP DoS.
  • حفاظت از حملات متداول وب - شناسایی حملات امنیتی مشترک برنامه وب.
  • تشخیص اتوماسیون - شناسایی ربات ها ، خزنده ها ، اسکنرها و سایر فعالیت های مخرب سطح.
  • ادغام با اسکن AV برای بارگذاری پرونده - پرونده های مخرب آپلود شده از طریق برنامه وب را شناسایی می کند.
  • ردیابی داده های حساس - استفاده از کارت اعتباری را ردیابی می کند و نشت را مسدود می کند.
  • Trojan Protection - اسب های تروجان را تشخیص می دهد.
  • شناسایی نقص برنامه - هشدارهای مربوط به تنظیمات نادرست برنامه.
  • خطای تشخیص و پنهان کردن - مبدل پیام های خطا ارسال شده توسط سرور.

نصب و راه اندازی

در این راهنما چگونگی نصب ModSecurance و OWASP قوانین در CentOS 6 در حال اجرا Apache 2 نشان می دهد.

ابتدا باید از بروزرسانی سیستم خود اطمینان حاصل کنید.

 yum -y update

اگر Apache 2 را نصب نکرده اید ، اکنون آن را نصب کنید.

 yum -y install httpd

اکنون باید برخی از وابستگی ها را برای کارکرد ModSecurance نصب کنید. بسته به پیکربندی سرور شما ، ممکن است مقداری یا تمام این بسته ها نصب شوند. یام بسته هایی را که ندارید نصب می کند و در صورت نصب هر کدام از بسته ها ، به شما اطلاع می دهد.

 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

پیکربندی پیش فرض ModSecurance و پرونده نقشه برداری یونیکد را در فهرست Apache کپی کنید.

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

Apache را برای استفاده از ModSecurance پیکربندی کنید. 2 روش وجود دارد که می توانید این کار را انجام دهید.

 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

اگر آپاچی را قبل از استفاده از این راهنما نصب کرده بودید ، لازم است مجدداً آن را مجدداً راه اندازی کنید.

 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

اکنون آپاچی را مجدداً راه اندازی کنید.

 service httpd restart

در آخر ، فایلهای نصب را حذف کنید.

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

با استفاده از ModSecurance

به طور پیش فرض ، ModSecurance در حالت تشخیص فقط اجرا می شود ، این بدان معناست که همه معافیت های قانون را ثبت می کند اما هیچ اقدامی نخواهد کرد. این برای نصبهای جدید توصیه می شود ، بنابراین می توانید وقایع ایجاد شده در گزارش خطای Apache را تماشا کنید. پس از بررسی لاگ ، می توانید قبل از انتقال به حالت محافظت ، تصمیم بگیرید که آیا تغییراتی در خط مقررات یا غیرفعال کردن قانون (مشاهده زیر) وجود دارد.

برای مشاهده گزارش خطای Apache:

 cat /var/log/httpd/error_log

خط ModSecurance در گزارش خطای Apache به نه عنصر شکسته می شود. هر عنصر اطلاعاتی در مورد چرایی وقوع این رویداد ارائه می دهد.

  • بخش اول می گوید که چه پرونده ای از این رویداد موجب شده است.
  • قسمت دوم می گوید چه قاعده ای در پرونده قاعده شروع می شود.
  • عنصر سوم به شما می گوید که چه حکمی باعث شده است.
  • عنصر چهارم تجدید نظر در قانون را به شما می گوید.
  • عنصر پنجم شامل داده های ویژه برای اهداف اشکال زدایی است.
  • عنصر ششم شدت گزارش گیری از شدت این رویداد را مشخص می کند.
  • بخش هفتم توضیح می دهد که چه عملی رخ داده است و در چه مرحله ای اتفاق افتاده است.

توجه داشته باشید که بسته به پیکربندی سرور شما ممکن است برخی از عناصر وجود نداشته باشد.

برای تغییر ModSecurance در حالت protection ، پرونده conf را در ویرایشگر متن باز کنید:

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

... و تغییر دهید:

 SecRuleEngine DetectionOnly

به:

 SecRuleEngine On

اگر هنگام اجرای ModSecurance با هرگونه بلوکی مواجه شدید ، باید این قاعده را در ورود به سیستم خطای HTTP مشخص کنید. دستور "دم" به شما امکان می دهد تا گزارش ها را در زمان واقعی مشاهده کنید:

 tail -f /var/log/httpd/error_log

تکرار عملی که باعث شد بلاک در حین تماشای سیاهه ایجاد شود.

اصلاح یک قانون / غیرفعال کردن شناسه قانون

اصلاح یک خط مقدم فراتر از محدوده این آموزش است.

برای غیرفعال کردن یک قانون خاص ، شما آیین نامه ای را که در عنصر سوم موجود است (به عنوان مثال [id = 200000]) شناسایی می کنید و سپس آن را در پرونده پیکربندی Apache غیرفعال می کنید:

 nano /etc/httpd/conf/httpd.conf

... با افزودن موارد زیر به زیر پرونده با شناسه قانون:

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

اگر متوجه شدید ModSecurance تمام اقدامات را در وب سایت (های) خود مسدود می کند ، "مجموعه اصلی قانون" احتمالاً در حالت "خود محتوا" است. شما باید این مورد را به "تشخیص مشارکتی" تغییر دهید ، که فقط ناهنجاری ها را تشخیص داده و مسدود می کند. در عین حال ، می توانید گزینه های "Self-Contained" را جستجو کرده و در صورت تمایل ، آنها را تغییر دهید.

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

"کشف" را به "خود محتوا" تغییر دهید.

همچنین می توانید ModSecurance را پیکربندی کنید تا 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

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

نحوه نصب SonarQube در CentOS 7

نحوه نصب SonarQube در CentOS 7

با استفاده از یک سیستم متفاوت؟ SonarQube یک ابزار منبع باز برای توسعه سیستم با کیفیت است. در جاوا نوشته شده است و چندین پایگاه داده را پشتیبانی می کند. فراهم می کند

نصب Netdata در CentOS 7

نصب Netdata در CentOS 7

با استفاده از یک سیستم متفاوت؟ Netdata یک ستاره در حال افزایش در زمینه نظارت بر معیارهای سیستم در زمان واقعی است. در مقایسه با سایر ابزارهای مشابه ، Netdata:

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

HTTP / 2 جدیدترین نسخه پروتکل HTTP است که از SPDY مستقر است. توسعه آن توسط Google آغاز شده است و HTTP / 2 تا حد زیادی بر اساس پایگاه کد است

نحوه نصب سرور Starbound در CentOS 7

نحوه نصب سرور Starbound در CentOS 7

با استفاده از یک سیستم متفاوت؟ در این آموزش ، Ill در مورد نحوه راه اندازی یک سرور Starbound در CentOS 7 توضیح می دهد. پیش نیازها: شما باید این بازی را روی خود داشته باشید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

به یکی دیگر از آموزش های Vultr خوش آمدید. در اینجا ، نحوه نصب و اجرای سرور SAMP را یاد خواهید گرفت. این راهنما برای CentOS 6 نوشته شده است. پیش نیازهای مورد نیاز شما

Elgg را روی CentOS 7 نصب کنید

Elgg را روی CentOS 7 نصب کنید

با استفاده از یک سیستم متفاوت؟ Elgg یک موتور شبکه ای منبع باز است که امکان ایجاد محیط های اجتماعی از جمله شبکه های اجتماعی دانشگاه را فراهم می کند

نحوه نصب سرور RStudio در CentOS 7

نحوه نصب سرور RStudio در CentOS 7

RStudio Server نسخه وب RStudio است که مجموعه ای از ابزارهایی است که برای تسهیل کار برنامه نویسی با استفاده از زبان برنامه نویسی R طراحی شده است. در سه

نصب Bolt CMS در CentOS 7

نصب Bolt CMS در CentOS 7

Bolt یک CMS منبع باز است که به زبان PHP نوشته شده است. کد منبع Bolts در GitHub میزبانی شده است. این راهنما نحوه نصب Bolt CMS را در CentOS 7 Vult تازه نشان می دهد

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

Elasticsearch یک موتور جستجوی کامل و متن تحلیلی متن کامل است. به لطف تطبیق پذیری ، مقیاس پذیری و سهولت استفاده ، Elasticsearch گسترده تر است

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

بررسی اجمالی این مقاله به شما کمک می کند تا در هر زمان خوشه ای از Kubernetes را جمع کنید و با kubeadm در حال اجرا باشید. در این راهنما از دو سرور استفاده می شود

راه اندازی Sails.js برای توسعه در CentOS 7

راه اندازی Sails.js برای توسعه در CentOS 7

با استفاده از یک سیستم متفاوت؟ مقدمه Sails.js یک چارچوب MVC ��رای Node.js است ، شبیه به Ruby on Rails. این امر برای ایجاد برنامه های مدرن ver

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

Vultrs عملکرد IP فضای شما را امکان پذیر می سازد تا آزادی بی سابقه ای در اختصاص منابع IP شخصی شما به سرورهای cloud Vultr داشته باشید. ما کلی

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

مقدمه در این آموزش ، PufferPanel را در Vultr VPS ما نصب کنید. PufferPanel یک پانل کنترل با منبع آزاد و بصورت رایگان برای مدیریت شما است

ابزارهای نظارت بهتر برای اوبونتو و CentOS

ابزارهای نظارت بهتر برای اوبونتو و CentOS

معرفی سیستم های لینوکس به طور پیش فرض مانند top ، df و du با ابزارهای نظارتی ارسال می شوند که به نظارت بر فرایندها و فضای دیسک کمک می کنند. با این حال ، اغلب اوقات ، آنها به صورت طاقت فرسا هستند

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

با استفاده از یک سیستم متفاوت؟ LibreNMS یک سیستم نظارت بر شبکه منبع باز کاملاً برجسته است. از SNMP برای به دست آوردن داده ها از دستگاه های مختلف استفاده می کند. یک نوع

نحوه نصب Gitea در CentOS 7

نحوه نصب Gitea در CentOS 7

با استفاده از یک سیستم متفاوت؟ Gitea یک منبع کنترل جایگزین متن باز و خود میزبان است که توسط Git ساخته شده است. Gitea در Golang نوشته شده و هست

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد