Zend_Service_Rackspace_Servers

Zend_Service_ReCaptcha

Einführung

Zend_Service_ReCaptcha bietet einen Client für das » reCAPTCHA Web Service. Laut der reCAPTCHA Seite ist "reCAPTCHA ein freies CAPTCHA Service das hilft Bücher zu digitalisieren." Jedes reCAPTCHA verlangt das der Benutzer zwei Wörter eingibt, das erste ist das aktuelle CAPTCHA, und das zweite ist ein Wort von einem eingescannten Text bei dem Software für optische Zeichenerkennung (OCR) keine Identifizierung durchführen kann. Die Annahme ist das, wenn der Benutzer das erste Wort richtig angegeben hat, dass dann das zweite auch korrekt angegeben wird, und das dieses dann verwendet werden kann um OCR Software für die Digitalisierung von Büchern zu verbessern.

Um den reCAPTCHA Service zu verwenden muß man » einen Account unterzeichnen und eine oder mehrere Domains beim Service registrieren um öffentliche und private Schlüssel zu erzeugen.

Einfachste Verwendung

Ein Zend_Service_ReCaptcha Objekt instanzieren, und ihm den öffentlichen und privaten Schlüssel übergeben:

Example #1 Erstellung einer Instanz des reCAPTCHA Services

  1. $recaptcha = new Zend_Service_ReCaptcha($pubKey, $privKey);

Um das reCAPTCHA darzustellen, muß einfach die getHTML() Methode aufgerufen werden:

Example #2 Das reCAPTCHA darstellen

  1. echo $recaptcha->getHTML();

Wenn das Formular übertragen wurde, sollte man zwei Felder empfangen haben, 'recaptcha_challenge_field' und 'recaptcha_response_field'. Diese sind an die verify() Methode des reCAPTCHA Objekts zu übergeben:

Example #3 Das Formular Feld verifizieren

  1. $result = $recaptcha->verify(
  2.     $_POST['recaptcha_challenge_field'],
  3.     $_POST['recaptcha_response_field']
  4. );

Sobald man das Ergebnis hat, kann es getestet werden um zu sehen ob es gültig ist. Das Ergebnis ist ein Zend_Service_ReCaptcha_Response Objekt, welche eine isValid() Methode anbietet.

Example #4 Das reCAPTCHA prüfen

  1. if (!$result->isValid()) {
  2.     // Fehlerhafte Prüfung
  3. }

Noch einfacher zu verwenden ist der ReCaptcha Zend_Captcha Adapter, oder man verwendet diesen Adapter als Backend für das CAPTCHA Formularelement. In jedem Fall werden die Details der Darstellung und Prüfung des reCAPTCHA automatisch durchgeführt.

Email Adressen verstecken

Zend_Service_ReCaptcha_MailHide kann verwendet werden um Email Adressen zu verstecken. Es ersetzt den Teil der Email Adresse mit einem Link der ein Popup Fenster mit einer reCAPTCHA Challenge öffnet. Das Lösen der Challenge gibt die komplette Email Adresse zurück.

Um diese Komponente zu verwenden benötigt man » einen Account um öffentliche und private Schlüssel für die Mailhide API erstellen.

Example #5 Verwenden der Mail Hide Komponente

  1. // Die Mail Adresse die wir verstecken wollen
  2. $mail = 'mail@example.com';
  3.  
  4. // Eine Instanz der Mailhide Komponente erstellen, dieser die öffentlichen und
  5. // privaten Schlüssel übergeben sowie die Mail Adresse die man verstecken will
  6. $mailHide = new Zend_Service_ReCaptcha_Mailhide();
  7. $mailHide->setPublicKey($pubKey);
  8. $mailHide->setPrivateKey($privKey);
  9. $mailHide->setEmail($mail);
  10.  
  11. // Es darstellen
  12. print($mailHide);

Das obige Beispiel zeigt "m...@example.com" wobei "..." einen Link enthält der sich mit einem Popup Fenster und einer reCAPTCHA Challenge öffnet.

Der öffentliche Schlüssel, der private Schlüssel, und die Email Adresse können auch im Konstruktor der Klasse spezifiziert werden. Es existiert ein viertes Argument das es erlaubt einige Optionen für die Komponente zu setzen. Die vorhandenen Optionen sind in der folgenden Tabelle aufgelistet:

Zend_Service_ReCaptcha_MailHide options
Option Beschreibung Erwartete Werte Standard Werte
linkTitle Das Titel Attribut des Links string 'Reveal this e-mail address'
linkHiddenText Der Text welche den Popup Link enthält string '...'
popupWidth Die Breite des Popup Fensters int 500
popupHeight Die Höhe des Popup Fensters int 300

Die Konfigurations Optionen können gesetzt werden indem Sie als viertes Argument an den Konstruktor gesendet werden oder indem die setOptions($options) aufgerufen wird, welche ein assoziatives Array oder eine Instanz von Zend_Config entgegen nimmt.

Example #6 Viele versteckte Email Adressen erzeugen

  1. // Eine Instanz der Mailhide Komponente erstellen, dieser die öffentlichen und
  2. // privaten Schlüssel übergeben sowie einige Konfigurations Optionen
  3. $mailHide = new Zend_Service_ReCaptcha_Mailhide();
  4. $mailHide->setPublicKey($pubKey);
  5. $mailHide->setPrivateKey($privKey);
  6. $mailHide->setOptions(array(
  7.     'linkTitle' => 'Click me',
  8.     'linkHiddenText' => '+++++',
  9. ));
  10.  
  11. // Die Mail Adressen die wir verstecken wollen
  12. $mailAddresses = array(
  13.     'mail@example.com',
  14.     'johndoe@example.com',
  15.     'janedoe@example.com',
  16. );
  17.  
  18. foreach ($mailAddresses as $mail) {
  19.     $mailHide->setEmail($mail);
  20.     print($mailHide);
  21. }

Zend_Service_Rackspace_Servers