ModSecurity a OWASP na CentOS 6 a Apache 2

ModSecurity a OWASP na CentOS 6 a Apache 2

ModSecurity je webová aplikačná vrstva firewall navrhnutá pre prácu s IIS, Apache2 a Nginx. Je to bezplatný softvér s otvoreným zdrojovým kódom vydaný pod licenciou Apache 2.0. ModSecurity pomáha zabezpečiť váš webový server monitorovaním a analýzou návštevnosti vašich webových stránok. Robí to v reálnom čase na detekciu a blokovanie útokov z väčšiny známych exploitov pomocou regulárnych výrazov. Samotný ModSecurity poskytuje obmedzenú ochranu a na maximalizáciu ochrany sa spolieha na sady pravidiel.

Súbor základných pravidiel (CRS) projektu Open Web Application Security Project (OWASP) je súbor všeobecných pravidiel zisťovania útokov, ktoré poskytujú základnú úroveň ochrany pre akúkoľvek webovú aplikáciu. Sada pravidiel je bezplatná, s otvoreným zdrojom a v súčasnosti ju sponzoruje spoločnosť Spider Labs.

OWASP CRS poskytuje:

  • Ochrana HTTP – zisťovanie porušení protokolu HTTP a lokálne definovanej politiky používania.
  • Vyhľadávania čiernej listiny v reálnom čase – využíva reputáciu IP adresy tretej strany.
  • HTTP Denial of Service Protection - obrana proti zahlcovaniu HTTP a pomalým HTTP DoS útokom.
  • Common Web Attacks Protection – detekcia bežných bezpečnostných útokov webových aplikácií.
  • Detekcia automatizácie – Detekcia robotov, prehľadávačov, skenerov a iných povrchových škodlivých aktivít.
  • Integrácia s AV skenovaním nahrávania súborov – deteguje škodlivé súbory nahrané cez webovú aplikáciu.
  • Sledovanie citlivých údajov – sleduje používanie kreditnej karty a blokuje úniky.
  • Ochrana proti trójskym koňom – Detekuje trójske kone.
  • Identifikácia chýb aplikácie - upozornenia na nesprávne konfigurácie aplikácie.
  • Detekcia a skrytie chýb – maskovanie chybových správ odoslaných serverom.

Inštalácia

Táto príručka vám ukáže, ako nainštalovať sadu pravidiel ModSecurity a OWASP na CentOS 6 so systémom Apache 2.

Najprv sa musíte uistiť, že váš systém je aktuálny.

 yum -y update

Ak ste nenainštalovali Apache 2, nainštalujte si ho teraz.

 yum -y install httpd

Teraz musíte nainštalovať niektoré závislosti, aby ModSecurity fungoval. V závislosti od konfigurácie vášho servera môžu byť niektoré alebo všetky tieto balíky už nainštalované. Yum nainštaluje balíky, ktoré nemáte, a bude vás informovať, ak sú už niektoré balíky nainštalované.

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

Zmeňte adresár a stiahnite si zdrojový kód z webovej stránky ModSecuity. Aktuálna stabilná verzia je 2.8.

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

Rozbaľte balík a prejdite do jeho adresára.

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

Nakonfigurujte a skompilujte zdrojový kód.

 ./configure
 make
 make install

Skopírujte predvolenú konfiguráciu ModSecurity a mapovací súbor Unicode do adresára Apache.

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

Nakonfigurujte Apache na používanie ModSecurity. Môžete to urobiť 2 spôsobmi.

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

... alebo použite textový editor ako nano:

 nano /etc/httpd/conf/httpd.conf

V spodnej časti tohto súboru na samostatný riadok pridajte toto:

 LoadModule security2_module modules/mod_security2.so

Teraz môžete spustiť Apache a nakonfigurovať ho tak, aby sa spustil pri štarte.

 service httpd start
 chkconfig httpd on

Ak ste mali Apache nainštalovaný pred použitím tejto príručky, stačí ho reštartovať.

 service httpd restart

Teraz si môžete stiahnuť súbor základných pravidiel OWASP.

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

Teraz nakonfigurujte sadu pravidiel OWASP.

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

Ďalej musíte pridať sadu pravidiel do konfigurácie Apache. Opäť to môžeme urobiť dvoma spôsobmi.

 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

... alebo pomocou textového editora:

 nano /etc/httpd/conf/httpd.conf

V spodnej časti súboru na samostatné riadky pridajte toto:

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

Teraz reštartujte Apache.

 service httpd restart

Nakoniec odstráňte inštalačné súbory.

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

Pomocou ModSecurity

V predvolenom nastavení sa ModSecurity spúšťa v režime iba detekcie, čo znamená, že zaznamená všetky porušenia pravidiel, ale nevykoná žiadnu akciu. Toto sa odporúča pre nové inštalácie, aby ste mohli sledovať udalosti generované v protokole chýb Apache. Po prezretí denníka sa môžete rozhodnúť, či by sa pred prechodom do ochranného režimu mala vykonať akákoľvek úprava sady pravidiel alebo deaktivácia pravidla (pozri nižšie).

Ak chcete zobraziť denník chýb Apache:

 cat /var/log/httpd/error_log

Riadok ModSecurity v protokole chýb Apache je rozdelený do deviatich prvkov. Každý prvok poskytuje informácie o tom, prečo bola udalosť spustená.

  • Prvá časť hovorí, ktorý súbor pravidiel spustil túto udalosť.
  • Druhá časť hovorí, na ktorom riadku v súbore pravidiel pravidlo začína.
  • Tretí prvok vám povie, aké pravidlo bolo spustené.
  • Štvrtý prvok vám hovorí o revízii pravidla.
  • Piaty prvok obsahuje špeciálne údaje na účely ladenia.
  • Šiesty prvok definuje závažnosť protokolovania závažnosti tejto udalosti.
  • Siedma časť popisuje, aká akcia nastala a v akej fáze k nej došlo.

Upozorňujeme, že niektoré prvky môžu chýbať v závislosti od konfigurácie vášho servera.

Ak chcete zmeniť ModSecurity na ochranný režim, otvorte súbor conf v textovom editore:

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

...a zmeniť:

 SecRuleEngine DetectionOnly

komu:

 SecRuleEngine On

Ak narazíte na nejaké bloky, keď je spustený ModSecurity, musíte pravidlo identifikovať v protokole chýb HTTP. Príkaz „chvost“ vám umožňuje sledovať záznamy v reálnom čase:

 tail -f /var/log/httpd/error_log

Opakujte akciu, ktorá spôsobila zablokovanie pri sledovaní denníka.

Úprava sady pravidiel/zakázanie ID pravidla

Úprava sady pravidiel presahuje rámec tohto návodu.

Ak chcete zakázať konkrétne pravidlo, identifikujte ID pravidla, ktoré je v treťom prvku (napríklad [id=200000]) a potom ho zakážete v konfiguračnom súbore Apache:

 nano /etc/httpd/conf/httpd.conf

... pridaním nasledujúceho na koniec súboru s ID pravidla:

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

Ak zistíte, že modul ModSecurity blokuje všetky akcie na vašich webových stránkach, potom je „Súprava základných pravidiel“ pravdepodobne v režime „Samostatný“. Musíte to zmeniť na „spoločnú detekciu“, ktorá zisťuje a blokuje iba anomálie. Zároveň sa môžete pozrieť na možnosti „Self-Contained“ a zmeniť ich, ak si to želáte.

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

Zmeňte "detekciu" na "Self-Contained".

Môžete tiež nakonfigurovať ModSecurity tak, aby umožnil vašej IP cez bránu firewall webovej aplikácie (WAF) bez protokolovania:

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

... alebo s prihlásením:

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

Install Plesk on CentOS 7

Install Plesk on CentOS 7

Using a Different System? Plesk is a proprietary web host control panel that allows users to administer their personal and/or clients websites, databases

Ako nainštalovať Squid Proxy na CentOS

Ako nainštalovať Squid Proxy na CentOS

Squid je populárny bezplatný linuxový program, ktorý vám umožňuje vytvoriť webový proxy server na presmerovanie. V tejto príručke uvidíte, ako nainštalovať Squid na CentOS, aby vás zmenil

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Úvod Lighttpd je fork Apache, ktorého cieľom je byť oveľa menej náročný na zdroje. Je ľahký, odtiaľ jeho názov, a jeho použitie je celkom jednoduché. Installin

Konfigurácia statickej siete a IPv6 na CentOS 7

Konfigurácia statickej siete a IPv6 na CentOS 7

VULTR nedávno vykonal zmeny na ich konci a všetko by teraz malo fungovať dobre po vybalení so zapnutým NetworkManagerom. Ak chcete deaktivovať

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Icinga2 je výkonný monitorovací systém a pri použití v modeli master-client môže nahradiť potrebu monitorovacích kontrol založených na NRPE. Hlavný klient

Ako nainštalovať Apache Cassandra 3.11.x na CentOS 7

Ako nainštalovať Apache Cassandra 3.11.x na CentOS 7

Používate iný systém? Apache Cassandra je bezplatný a otvorený systém správy databáz NoSQL, ktorý je navrhnutý tak, aby poskytoval škálovateľnosť, vysokú

Ako nainštalovať Microweber na CentOS 7

Ako nainštalovať Microweber na CentOS 7

Používate iný systém? Microweber je open source drag and drop CMS a online obchod. Zdrojový kód Microweber je umiestnený na GitHub. Tento návod vám to ukáže

Ako nainštalovať Mattermost 4.1 na CentOS 7

Ako nainštalovať Mattermost 4.1 na CentOS 7

Používate iný systém? Mattermost je open source, samostatne hosťovaná alternatíva k službe posielania správ Slack SAAS. Inými slovami, s Mattermostom môžete cca

Vytvorenie siete serverov Minecraft pomocou BungeeCord na Debian 8, Debian 9 alebo CentOS 7

Vytvorenie siete serverov Minecraft pomocou BungeeCord na Debian 8, Debian 9 alebo CentOS 7

Čo budete potrebovať Vultr VPS s aspoň 1 GB RAM. Prístup SSH (s oprávneniami root/administrátor). Krok 1: Inštalácia BungeeCord Najprv veci

Umožňuje šifrovanie na Plesku

Umožňuje šifrovanie na Plesku

Ovládací panel Plesk obsahuje veľmi peknú integráciu pre Lets Encrypt. Lets Encrypt je jedným z mála poskytovateľov SSL, ktorí rozdávajú kompletné certifikáty

Umožňuje šifrovanie na cPanel

Umožňuje šifrovanie na cPanel

Lets Encrypt je certifikačná autorita, ktorá sa venuje bezplatnému poskytovaniu certifikátov SSL. cPanel vytvoril úhľadnú integráciu, takže vy a váš klient

Ako nainštalovať Concrete5 na CentOS 7

Ako nainštalovať Concrete5 na CentOS 7

Používate iný systém? Concrete5 je open source CMS, ktorý ponúka mnoho charakteristických a užitočných funkcií, ktoré pomáhajú redaktorom jednoducho vytvárať obsah

Ako nainštalovať revíznu tabuľu na CentOS 7

Ako nainštalovať revíznu tabuľu na CentOS 7

Používate iný systém? Review Board je bezplatný a otvorený zdrojový nástroj na kontrolu zdrojového kódu, dokumentácie, obrázkov a mnohých ďalších. Je to webový softvér

Nastavte overenie HTTP pomocou Nginx na CentOS 7

Nastavte overenie HTTP pomocou Nginx na CentOS 7

V tejto príručke sa dozviete, ako nastaviť HTTP autentifikáciu pre webový server Nginx spustený na CentOS 7. Požiadavky Na začiatok budete potrebovať

Ako nainštalovať YOURLS na CentOS 7

Ako nainštalovať YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je open source aplikácia na skrátenie adresy URL a analýzu údajov. V tomto článku sa budeme zaoberať procesom inštalácie

Ako nainštalovať a nakonfigurovať ArangoDB na CentOS 7

Ako nainštalovať a nakonfigurovať ArangoDB na CentOS 7

Používate iný systém? Úvod ArangoDB je open source databáza NoSQL s flexibilným dátovým modelom pre dokumenty, grafy a hodnoty kľúča. to je

Použitie Etckeeper na kontrolu verzií /etc

Použitie Etckeeper na kontrolu verzií /etc

Úvod Adresár /etc/ hrá rozhodujúcu úlohu v spôsobe fungovania systému Linux. Dôvodom je skutočnosť, že takmer každá konfigurácia systému

Prečo by ste mali používať SSHFS? Ako pripojiť vzdialený súborový systém s SSHFS na CentOS 6

Prečo by ste mali používať SSHFS? Ako pripojiť vzdialený súborový systém s SSHFS na CentOS 6

Mnoho systémových administrátorov spravuje veľké množstvo serverov. Keď je potrebné pristupovať k súborom cez rôzne servery, prihlásenie do každého z nich samostatne ca

Nastavenie servera Half Life 2 na CentOS 6

Nastavenie servera Half Life 2 na CentOS 6

Tento tutoriál sa bude zaoberať procesom inštalácie herného servera Half Life 2 na systém CentOS 6. Krok 1: Inštalácia predpokladov Aby ste mohli nastaviť ou

Ako nainštalovať Laravel GitScrum na CentOS 7

Ako nainštalovať Laravel GitScrum na CentOS 7

Laravel GitScrum alebo GitScrum je nástroj na zvýšenie produktivity s otvoreným zdrojom určený na pomoc vývojovým tímom implementovať metodiku Scrum podobným spôsobom.

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac