ModSecurity ja OWASP CentOS 6:ssa ja Apache 2:ssa

ModSecurity ja OWASP CentOS 6:ssa ja Apache 2:ssa

ModSecurity on verkkosovelluskerroksen palomuuri, joka on suunniteltu toimimaan IIS:n, Apache2:n ja Nginxin kanssa. Se on ilmainen avoimen lähdekoodin ohjelmisto, joka on julkaistu Apache-lisenssillä 2.0. ModSecurity auttaa suojaamaan verkkopalvelimesi seuraamalla ja analysoimalla verkkosivustosi liikennettä. Se tekee tämän reaaliajassa havaitakseen ja estääkseen useimpien tunnetuimpien hyväksikäyttötoimintojen hyökkäykset säännöllisten lausekkeiden avulla. ModSecurity tarjoaa yksinään rajoitetun suojan ja luottaa sääntöihin suojan maksimoimiseksi.

Open Web Application Security Project (OWASP) Core Rule Set (CRS) on joukko yleisiä hyökkäysten havaitsemissääntöjä, jotka tarjoavat perussuojauksen mille tahansa verkkosovellukselle. Sääntösarja on ilmainen, avoimen lähdekoodin, ja tällä hetkellä Spider Labsin sponsoroima.

OWASP CRS tarjoaa:

  • HTTP-suojaus - havaitsee HTTP-protokollan ja paikallisesti määritellyn käyttökäytännön rikkomukset.
  • Reaaliaikaiset mustan listan haut - hyödyntää kolmannen osapuolen IP-mainetta.
  • HTTP Denial of Service Protection - suojaus HTTP-tulvaa ja hitaita HTTP DoS -hyökkäyksiä vastaan.
  • Common Web Attack Protection – yleisten verkkosovellusten tietoturvahyökkäysten havaitseminen.
  • Automation Detection - Havaitsee robotteja, indeksointirobotteja, skannereita ja muuta pinnallista haitallista toimintaa.
  • Integrointi AV Scanning for File Uploads -toiminnon kanssa – havaitsee verkkosovelluksen kautta ladatut haitalliset tiedostot.
  • Arkaluonteisten tietojen seuranta - Seuraa luottokorttien käyttöä ja estää vuodot.
  • Troijan suojaus – Tunnistaa troijalaisia.
  • Sovellusvirheiden tunnistaminen - hälytykset sovelluksen virheellisistä määrityksistä.
  • Virheiden havaitseminen ja piilottaminen - Palvelimen lähettämien virheilmoitusten peittäminen.

Asennus

Tämä opas näyttää, kuinka ModSecurity- ja OWASP-säännöt asennetaan CentOS 6:een, jossa on Apache 2.

Ensin sinun on varmistettava, että järjestelmäsi on ajan tasalla.

 yum -y update

Jos et ole asentanut Apache 2:ta, asenna se nyt.

 yum -y install httpd

Sinun on nyt asennettava joitain riippuvuuksia, jotta ModSecurity toimii. Palvelimen kokoonpanosta riippuen osa tai kaikki näistä paketeista voi olla jo asennettuna. Yum asentaa paketit, joita sinulla ei ole, ja ilmoittaa sinulle, jos jokin paketeista on jo asennettu.

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

Vaihda hakemistoa ja lataa lähdekoodi ModSecuity-verkkosivustolta. Nykyinen vakaa versio on 2.8.

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

Pura paketti ja vaihda sen hakemistoon.

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

Määritä ja käännä lähdekoodi.

 ./configure
 make
 make install

Kopioi oletusarvoinen ModSecurity-kokoonpano ja unicode-kartoitustiedosto Apache-hakemistoon.

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

Määritä Apache käyttämään ModSecurityä. Voit tehdä tämän kahdella tavalla.

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

... tai käytä tekstieditoria, kuten nano:

 nano /etc/httpd/conf/httpd.conf

Lisää tiedoston alareunaan erilliselle riville tämä:

 LoadModule security2_module modules/mod_security2.so

Voit nyt käynnistää Apachen ja määrittää sen käynnistymään käynnistyksen yhteydessä.

 service httpd start
 chkconfig httpd on

Jos sinulla oli Apache asennettuna ennen tämän oppaan käyttöä, sinun tarvitsee vain käynnistää se uudelleen.

 service httpd restart

Voit nyt ladata OWASP-ydinsääntöjoukon.

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

Määritä nyt OWASP-säännöt.

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

Seuraavaksi sinun on lisättävä sääntöjoukko Apache-kokoonpanoon. Jälleen voimme tehdä tämän kahdella tavalla.

 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

... tai tekstieditorilla:

 nano /etc/httpd/conf/httpd.conf

Lisää tiedoston alareunaan eri riveille tämä:

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

Käynnistä nyt Apache uudelleen.

 service httpd restart

Poista lopuksi asennustiedostot.

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

ModSecurityn käyttö

Oletuksena ModSecurity toimii vain tunnistustilassa, mikä tarkoittaa, että se kirjaa kaikki sääntökatkot mutta ei ryhdy toimiin. Tätä suositellaan uusille asennuksille, jotta voit katsella Apache-virhelokissa luotuja tapahtumia. Tarkasteltuasi lokia, voit päättää, pitäisikö sääntöjoukkoa muuttaa tai sääntö poistaa käytöstä (katso alla) ennen suojaustilaan siirtymistä.

Apache-virhelokin tarkasteleminen:

 cat /var/log/httpd/error_log

Apache-virhelokin ModSecurity-rivi on jaettu yhdeksään elementtiin. Jokainen elementti antaa tietoa siitä, miksi tapahtuma käynnistyi.

  • Ensimmäinen osa kertoo, mikä sääntötiedosto käynnisti tämän tapahtuman.
  • Toinen osa kertoo, millä rivillä sääntötiedostossa sääntö alkaa.
  • Kolmas elementti kertoo, mikä sääntö käynnistettiin.
  • Neljäs elementti kertoo säännön päivityksen.
  • Viides elementti sisältää erityisiä tietoja virheenkorjaustarkoituksiin.
  • Kuudes elementti määrittää tämän tapahtuman vakavuuden kirjaamisen vakavuuden.
  • Seitsemäs osa kuvaa, mitä toimintaa tapahtui ja missä vaiheessa se tapahtui.

Huomaa, että jotkin elementit saattavat puuttua palvelimesi kokoonpanosta riippuen.

Voit muuttaa ModSecurityn suojaustilaan avaamalla conf-tiedoston tekstieditorissa:

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

... ja muuta:

 SecRuleEngine DetectionOnly

vastaanottajalle:

 SecRuleEngine On

Jos kohtaat estoja ModSecurityn ollessa käynnissä, sinun on tunnistettava sääntö HTTP-virhelokista. "Tail"-komennon avulla voit katsella lokeja reaaliajassa:

 tail -f /var/log/httpd/error_log

Toista eston aiheuttanut toimenpide samalla kun katsot lokia.

Sääntöjoukon muokkaaminen/sääntötunnuksen poistaminen käytöstä

Sääntöjoukon muokkaaminen ei kuulu tämän opetusohjelman piiriin.

Jos haluat poistaa tietyn säännön käytöstä, määritä sääntötunnus, joka on kolmannessa elementissä (esimerkiksi [id=200000]) ja poista se sitten Apache-määritystiedostosta:

 nano /etc/httpd/conf/httpd.conf

... lisäämällä tiedoston alaosaan sääntötunnuksella:

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

Jos huomaat, että ModSecurity estää kaikki toiminnot verkkosivustollasi, "Core Rule Set" on luultavasti "Self-Contained"-tilassa. Sinun on vaihdettava tämä "Yhteiskäyttöön", joka havaitsee ja estää vain poikkeamat. Samalla voit tarkastella "Self-Contained" -vaihtoehtoja ja muuttaa niitä, jos haluat tehdä niin.

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

Muuta "tunnistus" arvoksi "Self-Contained".

Voit myös määrittää ModSecurityn sallimaan IP-osoitteesi verkkosovelluksen palomuurin (WAF) läpi kirjautumatta:

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

... tai kirjauksella:

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

Asenna Plesk CentOS 7:ään

Asenna Plesk CentOS 7:ään

Käytätkö erilaista järjestelmää? Plesk on patentoitu verkkoisäntäohjauspaneeli, jonka avulla käyttäjät voivat hallita henkilökohtaisia ​​ja/tai asiakkaidensa verkkosivustoja, tietokantoja

Kuinka asentaa Squid Proxy CentOS:ään

Kuinka asentaa Squid Proxy CentOS:ään

Squid on suosittu, ilmainen Linux-ohjelma, jonka avulla voit luoda edelleenlähetysverkkovälityspalvelimen. Tässä oppaassa näet, kuinka Squid asennetaan CentOS:ään kääntääksesi sinut

Lighttpd:n (LLMP Stack) asentaminen CentOS 6:een

Lighttpd:n (LLMP Stack) asentaminen CentOS 6:een

Johdanto Lighttpd on Apachen haarukka, jonka tarkoituksena on olla paljon vähemmän resurssiintensiivinen. Se on kevyt, tästä syystä sen nimi, ja on melko yksinkertainen käyttää. Asenna

Staattisen verkon ja IPv6:n määrittäminen CentOS 7:ssä

Staattisen verkon ja IPv6:n määrittäminen CentOS 7:ssä

VULTR on äskettäin tehnyt muutoksia heidän omiinsa, ja kaiken pitäisi nyt toimia hyvin heti, kun NetworkManager on käytössä. Jos haluat poistaa käytöstä

Icinga2:n muokkaaminen käyttämään pää/asiakasmallia CentOS 6:ssa tai CentOS 7:ssä

Icinga2:n muokkaaminen käyttämään pää/asiakasmallia CentOS 6:ssa tai CentOS 7:ssä

Icinga2 on tehokas valvontajärjestelmä, ja master-client-mallissa käytettynä se voi korvata NRPE-pohjaisten valvontatarkastusten tarpeen. Pääasiakas

Apache Cassandra 3.11.x:n asentaminen CentOS 7:ään

Apache Cassandra 3.11.x:n asentaminen CentOS 7:ään

Käytätkö erilaista järjestelmää? Apache Cassandra on ilmainen ja avoimen lähdekoodin NoSQL-tietokannan hallintajärjestelmä, joka on suunniteltu tarjoamaan skaalautuvuutta, hig.

Kuinka asentaa Microweber CentOS 7:ään

Kuinka asentaa Microweber CentOS 7:ään

Käytätkö erilaista järjestelmää? Microweber on avoimen lähdekoodin vedä ja pudota sisällönhallintajärjestelmä ja verkkokauppa. Microweber-lähdekoodia isännöidään GitHubissa. Tämä opas näyttää sinulle

Mattermost 4.1:n asentaminen CentOS 7:ään

Mattermost 4.1:n asentaminen CentOS 7:ään

Käytätkö erilaista järjestelmää? Mattermost on avoimen lähdekoodin itseisännöity vaihtoehto Slack SAAS -viestipalvelulle. Toisin sanoen Mattermostin avulla voit noin

Minecraft-palvelinverkon luominen BungeeCordilla Debian 8:ssa, Debian 9:ssä tai CentOS 7:ssä

Minecraft-palvelinverkon luominen BungeeCordilla Debian 8:ssa, Debian 9:ssä tai CentOS 7:ssä

Mitä tarvitset Vultr VPS:n, jossa on vähintään 1 Gt RAM-muistia. SSH-käyttö (pääkäyttäjän/järjestelmänvalvojan oikeuksilla). Vaihe 1: BungeeCordin asentaminen Ensimmäiset asiat ensin

Sallii salauksen Pleskissä

Sallii salauksen Pleskissä

Plesk-ohjauspaneelissa on erittäin mukava integraatio Lets Encryptille. Lets Encrypt on yksi ainoista SSL-palveluntarjoajista, jotka myöntävät varmenteita täydellisesti

Sallii salauksen cPanelissa

Sallii salauksen cPanelissa

Lets Encrypt on varmenneviranomainen, joka on omistautunut tarjoamaan SSL-varmenteita ilmaiseksi. cPanel on rakentanut siistin integraation sinulle ja asiakkaallesi

Kuinka asentaa Concrete5 CentOS 7:ään

Kuinka asentaa Concrete5 CentOS 7:ään

Käytätkö erilaista järjestelmää? Concrete5 on avoimen lähdekoodin sisällönhallintajärjestelmä, joka tarjoaa monia ainutlaatuisia ja hyödyllisiä ominaisuuksia, jotka auttavat toimittajia tuottamaan sisältöä helposti ja helposti.

Review Boardin asentaminen CentOS 7:ään

Review Boardin asentaminen CentOS 7:ään

Käytätkö erilaista järjestelmää? Review Board on ilmainen ja avoimen lähdekoodin työkalu lähdekoodin, dokumentaation, kuvien ja monien muiden tarkistamiseen. Se on web-pohjainen ohjelmisto

Asenna HTTP-todennus Nginxillä CentOS 7:ssä

Asenna HTTP-todennus Nginxillä CentOS 7:ssä

Tässä oppaassa opit määrittämään HTTP-todennuksen Nginx-verkkopalvelimelle, joka toimii CentOS 7:ssä. Vaatimukset Aloitaksesi tarvitset

Kuinka asentaa YOURLS CentOS 7:ään

Kuinka asentaa YOURLS CentOS 7:ään

YOURLS (Your Own URL Shortener) on avoimen lähdekoodin URL-osoitteiden lyhennys- ja data-analytiikkasovellus. Tässä artikkelissa käsittelemme asennusprosessia

Kuinka asentaa ja määrittää ArangoDB CentOS 7: ssä

Kuinka asentaa ja määrittää ArangoDB CentOS 7: ssä

Käytätkö erilaista järjestelmää? Johdanto ArangoDB on avoimen lähdekoodin NoSQL-tietokanta, jossa on joustava tietomalli asiakirjoille, kaavioille ja avainarvoille. se on

Etckeeperin käyttäminen /etc-version hallintaan

Etckeeperin käyttäminen /etc-version hallintaan

Johdanto /etc/-hakemistolla on tärkeä rooli Linux-järjestelmän toiminnassa. Syynä tähän on se, että lähes kaikki järjestelmäkokoonpanot

Miksi sinun pitäisi käyttää SSHFS:ää? Kuinka asentaa etätiedostojärjestelmä SSHFS:llä CentOS 6:ssa

Miksi sinun pitäisi käyttää SSHFS:ää? Kuinka asentaa etätiedostojärjestelmä SSHFS:llä CentOS 6:ssa

Monet järjestelmänvalvojat hallitsevat suuria määriä palvelimia. Kun tiedostoja on käytettävä eri palvelimien kautta, kirjaudu jokaiseen erikseen n

Half Life 2 -palvelimen määrittäminen CentOS 6:lle

Half Life 2 -palvelimen määrittäminen CentOS 6:lle

Tämä opetusohjelma kattaa Half Life 2 -pelipalvelimen asennuksen CentOS 6 -järjestelmään. Vaihe 1: Edellytysten asentaminen Voit määrittää ou

Kuinka asentaa Laravel GitScrum CentOS 7:ään

Kuinka asentaa Laravel GitScrum CentOS 7:ään

Laravel GitScrum tai GitScrum on avoimen lähdekoodin tuottavuustyökalu, joka on suunniteltu auttamaan kehitysryhmiä ottamaan käyttöön Scrum-metodologian samalla tavalla.

Koneiden nousu: tekoälyn todelliset sovellukset

Koneiden nousu: tekoälyn todelliset sovellukset

Tekoäly ei ole tulevaisuudessa, se tässä nykyisyydessä Tässä blogissa Lue kuinka tekoälysovellukset ovat vaikuttaneet eri sektoreihin.

DDOS-hyökkäykset: lyhyt katsaus

DDOS-hyökkäykset: lyhyt katsaus

Oletko myös DDOS-hyökkäysten uhri ja hämmentynyt ehkäisymenetelmistä? Lue tämä artikkeli ratkaistaksesi kysymyksesi.

Oletko koskaan miettinyt, kuinka hakkerit ansaitsevat rahaa?

Oletko koskaan miettinyt, kuinka hakkerit ansaitsevat rahaa?

Olet ehkä kuullut, että hakkerit ansaitsevat paljon rahaa, mutta oletko koskaan miettinyt, kuinka he ansaitsevat tuollaista rahaa? keskustellaan.

Googlen vallankumouksellisia keksintöjä, jotka helpottavat elämääsi.

Googlen vallankumouksellisia keksintöjä, jotka helpottavat elämääsi.

Haluatko nähdä Googlen vallankumouksellisia keksintöjä ja kuinka nämä keksinnöt muuttivat jokaisen ihmisen elämää nykyään? Lue sitten blogia nähdäksesi Googlen keksinnöt.

Essential perjantai: Mitä tekoäly-ohjatuille autoille tapahtui?

Essential perjantai: Mitä tekoäly-ohjatuille autoille tapahtui?

Konsepti itseohjautuvista autoista lähteä tielle tekoälyn avulla on ollut haaveena jo jonkin aikaa. Mutta useista lupauksista huolimatta niitä ei näy missään. Lue tämä blogi saadaksesi lisätietoja…

Teknologinen singulaarisuus: ihmissivilisaation kaukainen tulevaisuus?

Teknologinen singulaarisuus: ihmissivilisaation kaukainen tulevaisuus?

Kun tiede kehittyy nopeasti ja ottaa haltuunsa suuren osan ponnisteluistamme, myös riskit altistaa itsemme selittämättömälle singulariteetille kasvavat. Lue, mitä singulaarisuus voisi tarkoittaa meille.

Tietojen tallennuksen evoluutio – Infografiikka

Tietojen tallennuksen evoluutio – Infografiikka

Tietojen säilytystavat ovat kehittyneet mahdollisesti Datan syntymästä lähtien. Tämä blogi käsittelee tiedon tallennuksen kehitystä infografian pohjalta.

Big Datan referenssiarkkitehtuurikerrosten toiminnot

Big Datan referenssiarkkitehtuurikerrosten toiminnot

Blogista saat tietää Big Data -arkkitehtuurin eri kerroksista ja niiden toiminnoista yksinkertaisimmalla tavalla.

6 uskomatonta etua älykkäiden kotilaitteiden käyttämisestä elämässämme

6 uskomatonta etua älykkäiden kotilaitteiden käyttämisestä elämässämme

Tässä digitaalisessa maailmassa kodin älylaitteista on tullut tärkeä osa elämää. Tässä on muutamia älykkäiden kodin laitteiden hämmästyttäviä etuja, joiden avulla ne tekevät elämästämme elämisen arvoista ja yksinkertaisempaa.

macOS Catalina 10.15.4 -täydennyspäivitys aiheuttaa enemmän ongelmia kuin ratkaiseminen

macOS Catalina 10.15.4 -täydennyspäivitys aiheuttaa enemmän ongelmia kuin ratkaiseminen

Apple julkaisi äskettäin macOS Catalina 10.15.4 -lisäpäivityksen ongelmien korjaamiseksi, mutta näyttää siltä, ​​että päivitys aiheuttaa lisää ongelmia, jotka johtavat mac-koneiden tiilikaamiseen. Lue tämä artikkeli saadaksesi lisätietoja