Zum Ende der Metadaten springen
Zum Anfang der Metadaten

Sie zeigen eine alte Version dieser Seite an. Zeigen Sie die aktuelle Version an.

Unterschiede anzeigen Seitenhistorie anzeigen

Version 1 Nächste Version anzeigen »

Brute-Force-Schutz für ein Login-Formular

Login-Formulare bedürfen eines besonderen Schutzes, da der  Anwender in der Regel nach erfolgreichem Login authorisiert wird, auf Daten zuzugreifen. Missbrauch von Logins sollten daher mit einem Banning abgestraft werden. Verwenden Sie dazu das Plugin security\intrusion_detection. 

Controller
use brandbox\security\intrusion_detection;
...
/**
 * @param string $username
 * @param string $password
 */
public function login($username, $password) {

  $engineIntrusionDetection = $this
    ->getAppFactory(intrusion_detection\engine::class)
  ;

  $formIdentificationKey = 'my-login';
  
  // Anwender ist bereits gesperrt
  if($engineIntrusionDetection->isBanned($formIdentificationKey, $throwBanMessage = true)):
    throw new lib\exception\yourException();
  endif;

  // Brute Force Attacke verhindern
  if(true !== $engineIntrusionDetection->isValidRequest()):
    $engineIntrusionDetection->banIP($formIdentificationKey, $setIsBanned = true, $lifetime = 30);
    throw new lib\exception\yourException();
  endif;
}

Nach nochmaligem Aufruf des Logins soll dem Anwender das Login-Fenster nicht mehr angezeigt werden. 
In diesem Beispiel wurde der Anwender für 30 Sekunden gesperrt. Das Login-Fenster blenden Sie wie folgt aus:

View
{{#isNotBanned "my-login"}}
  <form>...</form>
{{/isNotBanned}}

Banning-Regeln 

  • Ein Anwender darf sich mit der gleichen IP 4x in 10 Minuten anmelden

  • Beliebig viele  Anwender der selben IP dürfen sich 100x in 10 Minuten anmelden

  • Ein Anwender darf sich mit der gleichen IP 8x in 60 Minuten anmelden

  • Beliebig viele Anwender einer IP dürfen sich 600x in 60 Minuten anmelden

Brute-Force-Schutz mit Captcha

Es ist möglich, Formulare mit einem Captcha anzureichern, falls der Anwender geblockt wurde. In diesem Fall werden Anwender nicht gebanned.

Controller
use brandbox\security\intrusion_detection;
...
/**
 * @param string $username
 * @param string $password
 */
public function login($username, $password) {

  $engineIntrusionDetection = $this
    ->getAppFactory(intrusion_detection\engine::class)
  ;

  $formIdentificationKey = 'my-login';
  
  // Anwender ist bereits gesperrt
  if($engineIntrusionDetection->isBlocked($formIdentificationKey)):
    throw new lib\exception\yourException();
  endif;

  // Anwender hat ein Captcha eingegben.
  // Bei Erfolg wird das banning aufgehoben und der Zyklus startet von vorn.
  if(!empty($captcha)):
    if(true === $engineIntrusionDetection->isValidCaptcha($captcha)):
      $engineIntrusionDetection->removeBanIP($formIdentificationKey);
    endif;
  endif;

  // Brute Force Attacke verhindern
  if(true !== $engineIntrusionDetection->isValidRequest()):
    $engineIntrusionDetection->banIP(
      $formIdentificationKey, 
      $setIsBanned = false, 
      $lifetime = 60 * 60
    );
    throw new lib\exception\yourException();
  endif;
}
View
{{#isNotBanned "my-login"}}
  <input type="input" name="captcha" id="captcha" value="" />
  <img src="{{captchaBase64}}" width="160" height="75" />
{{/isNotBanned}}
  • Keine Stichwörter