ModSecurity og OWASP på CentOS 6 og Apache 2

ModSecurity og OWASP på CentOS 6 og Apache 2

ModSecurity er en brannmur for nettapplikasjonslag designet for å fungere med IIS, Apache2 og Nginx. Det er gratis åpen kildekode-programvare utgitt under Apache-lisensen 2.0. ModSecurity hjelper deg med å sikre webserveren din ved å overvåke og analysere trafikken på nettstedet ditt. Den gjør dette i sanntid for å oppdage og blokkere angrep fra de fleste kjente utnyttelser ved å bruke regulære uttrykk. I seg selv gir ModSecurity begrenset beskyttelse og er avhengig av regelsett for å maksimere beskyttelsen.

Open Web Application Security Project (OWASP) Core Rule Set (CRS) er et sett med generiske angrepsdeteksjonsregler som gir et grunnleggende beskyttelsesnivå for enhver nettapplikasjon. Regelsettet er gratis, åpen kildekode og for tiden sponset av Spider Labs.

OWASP CRS gir:

  • HTTP-beskyttelse - oppdager brudd på HTTP-protokollen og en lokalt definert brukspolicy.
  • Svartelisteoppslag i sanntid – bruker tredjeparts IP-omdømme.
  • HTTP Denial of Service Protection - forsvar mot HTTP-flom og langsomme HTTP DoS-angrep.
  • Common Web Attacks Protection - oppdager vanlige nettapplikasjonssikkerhetsangrep.
  • Automatiseringsdeteksjon - Oppdager roboter, robotsøkeprogrammer, skannere og annen ondsinnet aktivitet.
  • Integrasjon med AV-skanning for filopplasting - oppdager skadelige filer lastet opp via nettapplikasjonen.
  • Spore sensitive data - Sporer kredittkortbruk og blokkerer lekkasjer.
  • Trojan Protection - Oppdager trojanske hester.
  • Identifikasjon av applikasjonsfeil - varsler om applikasjonsfeilkonfigurasjoner.
  • Feilgjenkjenning og skjul - Tilsløre feilmeldinger sendt av serveren.

Installasjon

Denne guiden viser deg hvordan du installerer ModSecurity og OWASP regelsett på CentOS 6 som kjører Apache 2.

Først må du sørge for at systemet ditt er oppdatert.

 yum -y update

Hvis du ikke har installert Apache 2, installer den nå.

 yum -y install httpd

Du må nå installere noen avhengigheter for at ModSecurity skal fungere. Avhengig av serverkonfigurasjonen kan noen eller alle disse pakkene allerede være installert. Yum vil installere pakkene du ikke har og informere deg om noen av pakkene allerede er installert.

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

Endre katalog og last ned kildekoden fra ModSecuity-nettstedet. Den nåværende stabile versjonen er 2.8.

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

Pakk ut pakken og bytt til katalogen.

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

Konfigurer og kompiler kildekoden.

 ./configure
 make
 make install

Kopier standard ModSecurity-konfigurasjon og unicode-tilordningsfilen til Apache-katalogen.

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

Konfigurer Apache til å bruke ModSecurity. Det er 2 måter du kan gjøre dette på.

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

... eller bruk et tekstredigeringsprogram som nano:

 nano /etc/httpd/conf/httpd.conf

På bunnen av den filen, på en egen linje, legg til dette:

 LoadModule security2_module modules/mod_security2.so

Du kan nå starte Apache og konfigurere den til å starte ved oppstart.

 service httpd start
 chkconfig httpd on

Hvis du hadde Apache installert før du brukte denne veiledningen, trenger du bare å starte den på nytt.

 service httpd restart

Du kan nå laste ned OWASP kjerneregelsettet.

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

Konfigurer nå OWASP-regelsettet.

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

Deretter må du legge til regelsettet til Apache-konfigurasjonen. Igjen kan vi gjøre dette på to måter.

 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

... eller med et tekstredigeringsprogram:

 nano /etc/httpd/conf/httpd.conf

Legg til dette nederst i filen på separate linjer:

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

Start Apache på nytt.

 service httpd restart

Til slutt sletter du installasjonsfilene.

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

Bruker ModSecurity

Som standard kjører ModSecurity i bare deteksjonsmodus, noe som betyr at den vil logge alle regelbrudd, men ikke gjøre noe. Dette anbefales for nye installasjoner, slik at du kan se hendelsene generert i Apache-feilloggen. Etter å ha gjennomgått loggen, kan du bestemme om det skal gjøres endringer i regelsettet eller deaktivering av regelen (se nedenfor) før du går over til beskyttelsesmodus.

Slik viser du Apache-feilloggen:

 cat /var/log/httpd/error_log

ModSecurity-linjen i Apache-feilloggen er delt inn i ni elementer. Hvert element gir informasjon om hvorfor hendelsen ble utløst.

  • Den første delen forteller hvilken regelfil som utløste denne hendelsen.
  • Den andre delen forteller hvilken linje i regelfilen regelen starter på.
  • Det tredje elementet forteller deg hvilken regel som ble utløst.
  • Det fjerde elementet forteller deg revisjonen av regelen.
  • Det femte elementet inneholder spesielle data for feilsøkingsformål.
  • Det sjette elementet definerer loggingsgraden for denne hendelsens alvorlighetsgrad.
  • Den syvende delen beskriver hvilken handling som skjedde og i hvilken fase den skjedde.

Merk at noen elementer kan være fraværende avhengig av konfigurasjonen til serveren din.

For å endre ModSecurity til beskyttelsesmodus, åpne conf-filen i et tekstredigeringsprogram:

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

... og endre:

 SecRuleEngine DetectionOnly

til:

 SecRuleEngine On

Hvis du støter på blokkeringer når ModSecurity kjører, må du identifisere regelen i HTTP-feilloggen. "hale"-kommandoen lar deg se loggene i sanntid:

 tail -f /var/log/httpd/error_log

Gjenta handlingen som forårsaket blokkeringen mens du ser på loggen.

Endre et regelsett/deaktivere en regel-ID

Å endre et regelsett er utenfor omfanget av denne opplæringen.

For å deaktivere en spesifikk regel, identifiserer du regel-ID-en som er i det tredje elementet (for eksempel [id=200000]) og deaktiverer den deretter i Apache-konfigurasjonsfilen:

 nano /etc/httpd/conf/httpd.conf

... ved å legge til følgende nederst i filen med regel-IDen:

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

Hvis du oppdager at ModSecurity blokkerer alle handlinger på nettsiden(e), er "Core Rule Set" sannsynligvis i "Selvstendig"-modus. Du må endre dette til "Collaborative Detection", som kun oppdager og blokkerer uregelmessigheter. Samtidig kan du se på "Self-Contained"-alternativene og endre dem hvis du ønsker å gjøre det.

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

Endre "deteksjon" til "Selvstendig".

Du kan også konfigurere ModSecurity til å tillate IP-en din gjennom nettapplikasjonens brannmur (WAF) uten å logge:

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

... eller med logging:

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

Installer Plesk på CentOS 7

Installer Plesk på CentOS 7

Bruker du et annet system? Plesk er et proprietært kontrollpanel for webverten som lar brukere administrere sine personlige og/eller klienters nettsteder, databaser

Slik installerer du Squid Proxy på CentOS

Slik installerer du Squid Proxy på CentOS

Squid er et populært, gratis Linux-program som lar deg lage en webproxy for videresending. I denne veiledningen vil du se hvordan du installerer Squid på CentOS for å gjøre deg om

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Introduksjon Lighttpd er en apachegaffel som har som mål å være mye mindre ressurskrevende. Den er lett, derav navnet, og er ganske enkel å bruke. Installer

Konfigurering av statisk nettverk og IPv6 på CentOS 7

Konfigurering av statisk nettverk og IPv6 på CentOS 7

VULTR har nylig gjort endringer på sin side, og alt skal nå fungere bra ut av boksen med NetworkManager aktivert. Skulle du ønske å deaktivere

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Icinga2 er et kraftig overvåkingssystem, og når det brukes i en master-klient-modell, kan det erstatte behovet for NRPE-baserte overvåkingskontroller. Mester-klienten

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy

Slik installerer du Microweber på CentOS 7

Slik installerer du Microweber på CentOS 7

Bruker du et annet system? Microweber er en åpen kildekode dra og slipp CMS og nettbutikk. Microweber-kildekoden er vert på GitHub. Denne guiden vil vise deg

Hvordan installere Vanilla Forum på CentOS 7

Hvordan installere Vanilla Forum på CentOS 7

Bruker du et annet system? Vanilla forum er en åpen kildekode-forumapplikasjon skrevet i PHP. Det er en fullt tilpassbar, enkel å bruke og støtter ekstern

Slik installerer du Mattermost 4.1 på CentOS 7

Slik installerer du Mattermost 4.1 på CentOS 7

Bruker du et annet system? Mattermost er et åpen kildekode, selvdrevet alternativ til Slack SAAS-meldingstjenesten. Med andre ord, med Mattermost kan du ca

Opprette et nettverk av Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Opprette et nettverk av Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Hva du trenger En Vultr VPS med minst 1 GB RAM. SSH-tilgang (med root/administratorrettigheter). Trinn 1: Installere BungeeCord Først

La oss kryptere på Plesk

La oss kryptere på Plesk

Plesk-kontrollpanelet har en veldig fin integrasjon for Lets Encrypt. Lets Encrypt er en av de eneste SSL-leverandørene som gir ut sertifikater komplett

La oss kryptere på cPanel

La oss kryptere på cPanel

Lets Encrypt er en sertifiseringsinstans dedikert til å tilby SSL-sertifikater gratis. cPanel har bygget en ryddig integrasjon slik at du og din klient

Hvordan installere Concrete5 på CentOS 7

Hvordan installere Concrete5 på CentOS 7

Bruker du et annet system? Concrete5 er et åpen kildekode CMS som tilbyr mange karakteristiske og nyttige funksjoner for å hjelpe redaktører med å produsere innhold enkelt og

Slik installerer du Review Board på CentOS 7

Slik installerer du Review Board på CentOS 7

Bruker du et annet system? Review Board er et gratis og åpen kildekodeverktøy for gjennomgang av kildekode, dokumentasjon, bilder og mye mer. Det er nettbasert programvare

Sett opp HTTP-autentisering med Nginx på CentOS 7

Sett opp HTTP-autentisering med Nginx på CentOS 7

I denne veiledningen lærer du hvordan du setter opp HTTP-autentisering for en Nginx-webserver som kjører på CentOS 7. Krav For å komme i gang trenger du

Slik installerer du GoAccess på CentOS 7

Slik installerer du GoAccess på CentOS 7

Bruker du et annet system? GoAccess er en åpen kildekode-nettlogganalysator. Du kan bruke den til analyse av logger på sanntidsbasis i enten terminalen eller

Hvordan installere YOURLS på CentOS 7

Hvordan installere YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) er en åpen kildekode-applikasjon for URL-forkorting og dataanalyse. I denne artikkelen vil vi dekke installasjonsprosessen

Hvordan installere og konfigurere ArangoDB på CentOS 7

Hvordan installere og konfigurere ArangoDB på CentOS 7

Bruker du et annet system? Introduksjon ArangoDB er en åpen kildekode NoSQL-database med en fleksibel datamodell for dokumenter, grafer og nøkkelverdier. Det er

Bruke Etckeeper for versjonskontroll av /etc

Bruke Etckeeper for versjonskontroll av /etc

Innledning /etc/-katalogen spiller en kritisk rolle i måten et Linux-system fungerer på. Grunnen til dette er fordi nesten alle systemkonfigurasjoner

Hvorfor bør du bruke SSHFS? Hvordan montere et eksternt filsystem med SSHFS på CentOS 6

Hvorfor bør du bruke SSHFS? Hvordan montere et eksternt filsystem med SSHFS på CentOS 6

Mange systemadministratorer administrerer store mengder servere. Når filer må åpnes på tvers av forskjellige servere, logger du på hver enkelt individuelt ca

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.

DDOS-angrep: en kort oversikt

DDOS-angrep: en kort oversikt

Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.

Har du noen gang lurt på hvordan hackere tjener penger?

Har du noen gang lurt på hvordan hackere tjener penger?

Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.

Evolusjon av datalagring – infografikk

Evolusjon av datalagring – infografikk

Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.

Funksjonaliteter til Big Data Reference Architecture Layers

Funksjonaliteter til Big Data Reference Architecture Layers

Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer