ModSecurity i OWASP na CentOS 6 i Apache 2

ModSecurity i OWASP na CentOS 6 i Apache 2

ModSecurity je vatrozid sloja web aplikacije dizajniran za rad s IIS-om, Apache2 i Nginxom. To je besplatan softver otvorenog koda objavljen pod licencom Apache 2.0. ModSecurity pomaže u zaštiti vašeg web poslužitelja praćenjem i analizom prometa vaše web stranice. To čini u stvarnom vremenu kako bi otkrio i blokirao napade većine poznatih eksploatacija pomoću regularnih izraza. Sam po sebi, ModSecurity pruža ograničenu zaštitu i oslanja se na skupove pravila kako bi maksimizirao zaštitu.

Osnovni skup pravila (CRS) Open Web Application Security Project (OWASP) skup je generičkih pravila za otkrivanje napada koja pružaju osnovnu razinu zaštite za bilo koju web aplikaciju. Skup pravila je besplatan, otvorenog koda i trenutno ga sponzorira Spider Labs.

OWASP CRS pruža:

  • HTTP zaštita - otkrivanje kršenja HTTP protokola i lokalno definirane politike upotrebe.
  • Traženje crne liste u stvarnom vremenu - koristi reputaciju IP-a treće strane.
  • HTTP Denial of Service Protection - obrana od HTTP poplave i sporih HTTP DoS napada.
  • Zaštita od uobičajenih web napada - otkrivanje uobičajenih sigurnosnih napada web aplikacija.
  • Detekcija automatizacije - otkrivanje botova, alata za indeksiranje, skenera i drugih površinskih zlonamjernih aktivnosti.
  • Integracija s AV skeniranjem za prijenos datoteka - otkriva zlonamjerne datoteke prenesene putem web aplikacije.
  • Praćenje osjetljivih podataka - Prati korištenje kreditnih kartica i blokira curenje.
  • Trojanska zaštita - otkriva trojanske konje.
  • Identifikacija nedostataka aplikacije - upozorenja o pogrešnim konfiguracijama aplikacije.
  • Otkrivanje i skrivanje pogrešaka - Prikrivanje poruka o greškama koje šalje poslužitelj.

Montaža

Ovaj vam vodič pokazuje kako instalirati ModSecurity i OWASP skup pravila na CentOS 6 koji pokreće Apache 2.

Prvo morate osigurati da je vaš sustav ažuriran.

 yum -y update

Ako niste instalirali Apache 2, instalirajte ga sada.

 yum -y install httpd

Sada morate instalirati neke ovisnosti kako bi ModSecurity radio. Ovisno o konfiguraciji vašeg poslužitelja, neki ili svi od ovih paketa možda su već instalirani. Yum će instalirati pakete koje nemate i obavijestiti vas ako je neki od paketa već instaliran.

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

Promijenite direktorij i preuzmite izvorni kod s web stranice ModSecuity. Trenutna stabilna verzija je 2.8.

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

Raspakirajte paket i promijenite njegov direktorij.

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

Konfigurirajte i kompajlirajte izvorni kod.

 ./configure
 make
 make install

Kopirajte zadanu konfiguraciju ModSecurity i datoteku za mapiranje Unicodea u Apache direktorij.

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

Konfigurirajte Apache da koristi ModSecurity. Postoje 2 načina na koje to možete učiniti.

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

... ili koristite uređivač teksta kao što je nano:

 nano /etc/httpd/conf/httpd.conf

Na dnu te datoteke, u zasebnom retku dodajte ovo:

 LoadModule security2_module modules/mod_security2.so

Sada možete pokrenuti Apache i konfigurirati ga za pokretanje pri pokretanju.

 service httpd start
 chkconfig httpd on

Ako ste imali instaliran Apache prije korištenja ovog vodiča, samo ga trebate ponovno pokrenuti.

 service httpd restart

Sada možete preuzeti osnovni skup pravila OWASP-a.

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

Sada konfigurirajte OWASP skup pravila.

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

Zatim morate dodati skup pravila u Apache konfiguraciju. Opet to možemo učiniti na dva načina.

 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

... ili s uređivačem teksta:

 nano /etc/httpd/conf/httpd.conf

Na dnu datoteke u zasebne retke dodajte ovo:

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

Sada ponovno pokrenite Apache.

 service httpd restart

Na kraju izbrišite instalacijske datoteke.

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

Korištenje ModSecurity

Prema zadanim postavkama, ModSecurity radi u načinu samo za otkrivanje, što znači da će zabilježiti sve prekide pravila, ali neće poduzeti ništa. Ovo se preporučuje za nove instalacije kako biste mogli gledati događaje generirane u zapisniku pogrešaka Apachea. Nakon pregleda zapisnika, možete odlučiti treba li napraviti bilo kakvu izmjenu skupa pravila ili onemogućavanje pravila (vidi dolje) prije prelaska u zaštitni način.

Za pregled zapisnika grešaka Apachea:

 cat /var/log/httpd/error_log

Redak ModSecurity u zapisniku pogrešaka Apachea podijeljen je na devet elemenata. Svaki element pruža informacije o tome zašto je događaj pokrenut.

  • Prvi dio govori koja je datoteka pravila pokrenula ovaj događaj.
  • Drugi dio govori na kojem retku u datoteci pravila pravilo počinje.
  • Treći element govori koje je pravilo pokrenuto.
  • Četvrti element govori o reviziji pravila.
  • Peti element sadrži posebne podatke za potrebe otklanjanja pogrešaka.
  • Šesti element definira ozbiljnost zapisivanja ozbiljnosti ovog događaja.
  • Sedmi dio opisuje koja se radnja dogodila i u kojoj se fazi dogodila.

Imajte na umu da neki elementi mogu biti odsutni ovisno o konfiguraciji vašeg poslužitelja.

Da biste promijenili ModSecurity u način zaštite, otvorite conf datoteku u uređivaču teksta:

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

... i promijeniti:

 SecRuleEngine DetectionOnly

do:

 SecRuleEngine On

Ako naiđete na bilo kakve blokove kada je ModSecurity pokrenut, tada morate identificirati pravilo u HTTP zapisniku pogrešaka. Naredba "rep" omogućuje vam da gledate zapisnike u stvarnom vremenu:

 tail -f /var/log/httpd/error_log

Ponovite radnju koja je uzrokovala blokadu dok gledate zapisnik.

Promjena skupa pravila/onemogućavanje ID-a pravila

Promjena skupa pravila izvan je opsega ovog vodiča.

Da biste onemogućili određeno pravilo, identificirate ID pravila koji se nalazi u trećem elementu (na primjer [id=200000]), a zatim ga onemogućite u Apache konfiguracijskoj datoteci:

 nano /etc/httpd/conf/httpd.conf

... dodavanjem sljedećeg na dno datoteke s ID-om pravila:

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

Ako ustanovite da ModSecurity blokira sve radnje na vašim web-stranicama, tada je "Set temeljnih pravila" vjerojatno u "samostalnom" načinu rada. Morate to promijeniti u "Collaborative Detection", koja otkriva i blokira samo anomalije. Istodobno, možete pogledati opcije "Samostalno" i promijeniti ih ako to želite.

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

Promijenite "detekciju" u "Samostalno".

Također možete konfigurirati ModSecurity da dopusti vaš IP putem vatrozida web aplikacije (WAF) bez evidentiranja:

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

... ili uz prijavu:

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

Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Korištenje drugog sustava? Apache Cassandra je besplatni i otvorenog koda NoSQL sustav upravljanja bazom podataka koji je osmišljen kako bi osigurao skalabilnost, visoku

Kako instalirati Microweber na CentOS 7

Kako instalirati Microweber na CentOS 7

Korištenje drugog sustava? Microweber je CMS i internetska trgovina otvorenog koda povuci i ispusti. Izvorni kod Microwebera nalazi se na GitHubu. Ovaj vodič će vam pokazati

Kako instalirati Mattermost 4.1 na CentOS 7

Kako instalirati Mattermost 4.1 na CentOS 7

Korištenje drugog sustava? Mattermost je open source alternativa Slack SAAS servisu za razmjenu poruka. Drugim riječima, s Mattermostom možete ca

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Što vam treba Vultr VPS s najmanje 1 GB RAM-a. SSH pristup (s root/administrativnim privilegijama). Korak 1: Instalacija BungeeCord-a Najprije

Omogućava šifriranje na Plesku

Omogućava šifriranje na Plesku

Upravljačka ploča Plesk ima vrlo lijepu integraciju za Lets Encrypt. Lets Encrypt je jedan od jedinih SSL pružatelja usluga koji u potpunosti izdaju certifikate

Omogućuje šifriranje na cPanelu

Omogućuje šifriranje na cPanelu

Lets Encrypt je tijelo za izdavanje certifikata posvećeno besplatnom pružanju SSL certifikata. cPanel je izgradio urednu integraciju tako da vi i vaš klijent

Kako instalirati Concrete5 na CentOS 7

Kako instalirati Concrete5 na CentOS 7

Korištenje drugog sustava? Concrete5 je CMS otvorenog koda koji nudi mnoge osebujne i korisne značajke koje pomažu urednicima u jednostavnoj proizvodnji sadržaja i

Kako instalirati ploču za pregled na CentOS 7

Kako instalirati ploču za pregled na CentOS 7

Korištenje drugog sustava? Review Board je besplatan alat otvorenog koda za pregled izvornog koda, dokumentacije, slika i još mnogo toga. To je web-bazirani softver

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

U ovom vodiču naučit ćete kako postaviti HTTP autentifikaciju za Nginx web poslužitelj koji radi na CentOS 7. Zahtjevi Da biste započeli, trebat će vam

Kako instalirati YOURLS na CentOS 7

Kako instalirati YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je aplikacija za skraćivanje URL-ova otvorenog koda i analizu podataka. U ovom članku ćemo pokriti proces instalacije

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Korištenje drugog sustava? Uvod ArangoDB je NoSQL baza podataka otvorenog koda s fleksibilnim modelom podataka za dokumente, grafikone i ključ-vrijednosti. to je

Korištenje Etckeepera za kontrolu verzija /etc

Korištenje Etckeepera za kontrolu verzija /etc

Uvod Direktorij /etc/ igra ključnu ulogu u načinu na koji Linux sustav funkcionira. Razlog tome je što je gotovo svaka konfiguracija sustava

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Mnogi administratori sustava upravljaju velikim količinama poslužitelja. Kada se datotekama treba pristupiti na različitim poslužiteljima, prijava na svaki pojedinačno ca

Postavljanje poslužitelja Half Life 2 na CentOS 6

Postavljanje poslužitelja Half Life 2 na CentOS 6

Ovaj vodič će pokriti proces instaliranja poslužitelja za igre Half Life 2 na sustavu CentOS 6. Korak 1: Instaliranje preduvjeta Kako biste postavili ou

Kako instalirati Laravel GitScrum na CentOS 7

Kako instalirati Laravel GitScrum na CentOS 7

Laravel GitScrum ili GitScrum je alat za produktivnost otvorenog koda dizajniran da pomogne razvojnim timovima da implementiraju Scrum metodologiju na sličan način.

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više