ModSecurity in OWASP na CentOS 6 in Apache 2

ModSecurity in OWASP na CentOS 6 in Apache 2

ModSecurity je požarni zid plasti spletne aplikacije, zasnovan za delo z IIS, Apache2 in Nginx. Je brezplačna odprtokodna programska oprema, izdana pod licenco Apache 2.0. ModSecurity pomaga zaščititi vaš spletni strežnik s spremljanjem in analizo prometa na vašem spletnem mestu. To počne v realnem času za odkrivanje in blokiranje napadov večine znanih zlorab z uporabo regularnih izrazov. ModSecurity sam po sebi zagotavlja omejeno zaščito in se opira na nabore pravil za čim večjo zaščito.

Nabor osnovnih pravil (CRS) Open Web Application Security Project (OWASP) je niz splošnih pravil za odkrivanje napadov, ki zagotavljajo osnovno raven zaščite za katero koli spletno aplikacijo. Nabor pravil je brezplačen, odprtokoden in trenutno sponzorira Spider Labs.

OWASP CRS zagotavlja:

  • Zaščita HTTP – odkrivanje kršitev protokola HTTP in lokalno definiranega pravilnika uporabe.
  • Iskanje črnih seznamov v realnem času - uporablja ugled IP tretjih oseb.
  • HTTP Denial of Service Protection – obramba pred poplavami HTTP in počasnimi napadi HTTP DoS.
  • Zaščita pred pogostimi spletnimi napadi - odkrivanje pogostih varnostnih napadov spletnih aplikacij.
  • Zaznavanje avtomatizacije – odkrivanje botov, pajkov, skenerjev in drugih površinskih zlonamernih dejavnosti.
  • Integracija z AV skeniranjem za nalaganje datotek - zazna zlonamerne datoteke, naložene prek spletne aplikacije.
  • Sledenje občutljivim podatkom - Sledi uporabi kreditnih kartic in blokira uhajanje.
  • Trojanska zaščita - zazna trojanske konje.
  • Prepoznavanje napak v aplikaciji – opozorila o napačnih konfiguracijah aplikacije.
  • Zaznavanje in skrivanje napak – prikrivanje sporočil o napakah, ki jih pošlje strežnik.

Namestitev

Ta vodnik vam pokaže, kako namestiti nabor pravil ModSecurity in OWASP na CentOS 6 z Apache 2.

Najprej morate zagotoviti, da je vaš sistem posodobljen.

 yum -y update

Če še niste namestili Apache 2, ga namestite zdaj.

 yum -y install httpd

Zdaj morate namestiti nekaj odvisnosti, da ModSecurity deluje. Odvisno od konfiguracije vašega strežnika so morda nekateri ali vsi ti paketi že nameščeni. Yum bo namestil pakete, ki jih nimate, in vas obvestil, če je kateri od paketov že nameščen.

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

Spremenite imenik in prenesite izvorno kodo s spletnega mesta ModSecuity. Trenutna stabilna različica je 2.8.

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

Ekstrahirajte paket in preklopite v njegov imenik.

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

Konfigurirajte in prevedite izvorno kodo.

 ./configure
 make
 make install

Kopirajte privzeto konfiguracijo ModSecurity in datoteko za preslikavo Unicode v imenik Apache.

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

Konfigurirajte Apache za uporabo ModSecurity. To lahko storite na 2 načina.

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

... ali uporabite urejevalnik besedil, kot je nano:

 nano /etc/httpd/conf/httpd.conf

Na dnu te datoteke v ločeni vrstici dodajte to:

 LoadModule security2_module modules/mod_security2.so

Zdaj lahko zaženete Apache in ga konfigurirate tako, da se zažene ob zagonu.

 service httpd start
 chkconfig httpd on

Če ste pred uporabo tega priročnika namestili Apache, ga morate samo znova zagnati.

 service httpd restart

Zdaj lahko prenesete osnovni nabor pravil OWASP.

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

Zdaj konfigurirajte nabor pravil OWASP.

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

Nato morate v konfiguracijo Apache dodati nabor pravil. Ponovno lahko to storimo 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

... ali z urejevalnikom besedil:

 nano /etc/httpd/conf/httpd.conf

Na dnu datoteke v ločenih vrsticah dodajte to:

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

Zdaj znova zaženite Apache.

 service httpd restart

Na koncu izbrišite namestitvene datoteke.

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

Uporaba ModSecurity

ModSecurity privzeto deluje v načinu samo za zaznavanje, kar pomeni, da bo zabeležil vse kršitve pravil, vendar ne bo ukrepal. To je priporočljivo za nove namestitve, tako da si lahko ogledate dogodke, ustvarjene v dnevniku napak Apache. Po pregledu dnevnika se lahko odločite, ali je treba narediti kakršno koli spremembo nabora pravil ali onemogočiti pravilo (glejte spodaj), preden se premaknete v zaščitni način.

Za ogled dnevnika napak Apache:

 cat /var/log/httpd/error_log

Vrstica ModSecurity v dnevniku napak Apache je razdeljena na devet elementov. Vsak element zagotavlja informacije o tem, zakaj se je dogodek sprožil.

  • Prvi del pove, katera datoteka pravil je sprožila ta dogodek.
  • Drugi del pove, v kateri vrstici v datoteki pravil se pravilo začne.
  • Tretji element vam pove, katero pravilo je bilo sproženo.
  • Četrti element vam pove revizijo pravila.
  • Peti element vsebuje posebne podatke za namene odpravljanja napak.
  • Šesti element definira resnost beleženja resnosti tega dogodka.
  • Sedmi razdelek opisuje, katero dejanje se je zgodilo in v kateri fazi se je zgodilo.

Upoštevajte, da so nekateri elementi morda odsotni, odvisno od konfiguracije vašega strežnika.

Če želite spremeniti ModSecurity v zaščitni način, odprite datoteko conf v urejevalniku besedil:

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

... in spremeni:

 SecRuleEngine DetectionOnly

za:

 SecRuleEngine On

Če naletite na kakršne koli bloke, ko se izvaja ModSecurity, morate določiti pravilo v dnevniku napak HTTP. Ukaz "tail" vam omogoča ogled dnevnikov v realnem času:

 tail -f /var/log/httpd/error_log

Ponovite dejanje, ki je povzročilo blokado, medtem ko gledate dnevnik.

Spreminjanje nabora pravil/onemogočanje ID-ja pravila

Spreminjanje nabora pravil je izven obsega te vadnice.

Če želite onemogočiti določeno pravilo, določite ID pravila, ki je v tretjem elementu (na primer [id=200000]) in ga nato onemogočite v konfiguracijski datoteki Apache:

 nano /etc/httpd/conf/httpd.conf

... tako, da na dno datoteke z ID-jem pravila dodate naslednje:

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

Če ugotovite, da ModSecurity blokira vsa dejanja na vaših spletnih mestih, potem je "Nabor osnovnih pravil" verjetno v "samostojnem" načinu. To morate spremeniti v "Collaborative Detection", ki zazna in blokira samo anomalije. Hkrati si lahko ogledate možnosti "Samodejno" in jih spremenite, če to želite.

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

Spremenite "detection" v "Self-Contained".

ModSecurity lahko tudi konfigurirate tako, da dovoli vaš IP prek požarnega zidu spletne aplikacije (WAF) brez beleženja:

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

... ali z beleženjem:

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

Namestite Plesk na CentOS 7

Namestite Plesk na CentOS 7

Uporaba drugega sistema? Plesk je lastniška nadzorna plošča spletnega gostitelja, ki uporabnikom omogoča upravljanje svojih osebnih in/ali strank spletnih mest, baz podatkov

Kako namestiti Squid Proxy na CentOS

Kako namestiti Squid Proxy na CentOS

Squid je priljubljen brezplačen program za Linux, ki vam omogoča ustvarjanje spletnega proxyja za posredovanje. V tem priročniku boste videli, kako namestiti Squid na CentOS, da vas obrne

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je razdelek Apache, katerega namen je biti veliko manj intenziven vir. Je lahek, od tod tudi njegovo ime, in je precej preprost za uporabo. Namestite

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

VULTR je pred kratkim naredil spremembe na svoji strani in zdaj bi moralo vse delovati v redu iz škatle z omogočenim NetworkManagerjem. Če želite onemogočiti

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Icinga2 je zmogljiv sistem za spremljanje in če se uporablja v modelu glavni-odjemalec, lahko nadomesti potrebo po nadzornih pregledih, ki temeljijo na NRPE. Glavni naročnik

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Microweber na CentOS 7

Kako namestiti Microweber na CentOS 7

Uporaba drugega sistema? Microweber je odprtokodna povleci in spusti CMS in spletna trgovina. Izvorna koda Microweber gostuje na GitHubu. Ta vodnik vam bo pokazal

Kako namestiti Mattermost 4.1 na CentOS 7

Kako namestiti Mattermost 4.1 na CentOS 7

Uporaba drugega sistema? Mattermost je odprtokodna alternativa sporočilni storitvi Slack SAAS, ki jo gosti sami. Z drugimi besedami, z Mattermostom si pribl

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej

Omogočamo šifriranje na Plesku

Omogočamo šifriranje na Plesku

Nadzorna plošča Plesk ima zelo lepo integracijo za Lets Encrypt. Lets Encrypt je eden edinih ponudnikov SSL, ki izdaja potrdila v celoti

Namestite MariaDB 10 na CentOS 6

Namestite MariaDB 10 na CentOS 6

V času pisanja je MariaDB 10.1 razvojna različica MariaDB. Temelji na MariaDB 5.5 in vključuje funkcije, prenesene nazaj iz MySQL 5.6. Ther

Omogoča šifriranje na cPanelu

Omogoča šifriranje na cPanelu

Lets Encrypt je certifikacijski organ, ki je namenjen brezplačnemu zagotavljanju certifikatov SSL. cPanel je zgradil lepo integracijo za vas in vašo stranko

Kako namestiti Concrete5 na CentOS 7

Kako namestiti Concrete5 na CentOS 7

Uporaba drugega sistema? Concrete5 je odprtokodni CMS, ki ponuja številne značilne in uporabne funkcije za pomoč urednikom pri preprosti izdelavi vsebine.

Kako namestiti pregledno ploščo na CentOS 7

Kako namestiti pregledno ploščo na CentOS 7

Uporaba drugega sistema? Review Board je brezplačno in odprtokodno orodje za pregledovanje izvorne kode, dokumentacije, slik in še veliko več. Gre za spletno programsko opremo

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

V tem priročniku se boste naučili, kako nastaviti preverjanje pristnosti HTTP za spletni strežnik Nginx, ki deluje na CentOS 7. Zahteve Za začetek boste potrebovali

Kako namestiti YOURLS na CentOS 7

Kako namestiti YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je odprtokodna aplikacija za krajšanje URL-jev in analitiko podatkov. V tem članku bomo obravnavali postopek namestitve

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Uporaba drugega sistema? Uvod ArangoDB je odprtokodna baza podatkov NoSQL s prilagodljivim podatkovnim modelom za dokumente, grafe in ključe-vrednosti. je

Uporaba Etckeeperja za nadzor različic /etc

Uporaba Etckeeperja za nadzor različic /etc

Uvod Imenik /etc/ igra ključno vlogo pri delovanju sistema Linux. Razlog za to je skoraj vsaka sistemska konfiguracija

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Številni sistemski skrbniki upravljajo velike količine strežnikov. Ko je treba do datotek dostopati prek različnih strežnikov, se prijavite v vsakega posebej ca

Nastavitev strežnika Half Life 2 na CentOS 6

Nastavitev strežnika Half Life 2 na CentOS 6

Ta vadnica bo obravnavala postopek namestitve igralnega strežnika Half Life 2 na sistem CentOS 6. 1. korak: Namestitev predpogojev Za nastavitev ou

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več