Introduction

Opération Captcha

Tous les adaptateurs CAPTCHA implémentent Zend_Captcha_Adapter, qui ressemble à ceci :

  1. interface Zend_Captcha_Adapter extends Zend_Validate_Interface
  2. {
  3.     public function generate();
  4.  
  5.     public function render(Zend_View $view, $element = null);
  6.  
  7.     public function setName($name);
  8.  
  9.     public function getName();
  10.  
  11.     public function getDecorator();
  12.  
  13.     // De plus, pour satisfaire Zend_Validate_Interface :
  14.     public function isValid($value);
  15.  
  16.     public function getMessages();
  17.  
  18.     public function getErrors();
  19. }

Le mutateur et l'accesseur "name" sont utilisés pour spécifier et récupérer l'identifiant du CAPTCHA. getDecorator() peut être utilisé pour spécifier un décorateur Zend_Form soit par son nom ou en retournant un objet décorateur. Les vraies clés sont utilisées sauf pour generate() et render(). generate() est utilisé pour créer l'élément CAPTCHA. Ce processus typiquement stockera l'élément en session ainsi il pourra être utilisé pour comparaison dans les requêtes suivantes. render() est utilisé pour effectuer le rendu de l'information que représente le CAPTCHA - en image, en texte Figlet, en problème logique, ou tout autre type de CAPTCHA.

Un cas d'utilisation typique pourrait ressembler à ceci :

  1. // Créer une instance de Zend_View
  2. $view = new Zend_View();
  3.  
  4. // Requête original :
  5. $captcha = new Zend_Captcha_Figlet(array(
  6.     'name' => 'foo',
  7.     'wordLen' => 6,
  8.     'timeout' => 300,
  9. ));
  10. $id = $captcha->generate();
  11. echo $captcha->render($view);
  12.  
  13. // Lors de la requête suivante :
  14. // suppose que $captcha a été paramètré avant,
  15. // et que $value est la valeur soumise :
  16. if ($captcha->isValid($_POST['foo'], $_POST)) {
  17.     // Validated!
  18. }

Introduction