jeudi 26 février 2009

Grille ExtJS et Zend Framework (2eme partie)

Dans cette partie nous allons construire et afficher notre grille, pour ce faite nous avons besoin de définir ces propriétés et sa source de données (DataStore dans le jargon ExtJS).

DataStore

Le DataStore est un tableaux de données qui peut être charger depuis n’importe quel source de données (XML, JSON...etc) ,pour que notre grille puisse afficher des données elle doit être impérativement attacher un DataStore, à un moment donnée si nous voulons changer le contenu de notre grille nous devrons changer celui du DataStore.

Pour commencer nous allons créer un nouveau fichier javascript grille.js dans le dossier js et nous lui ajouterons les fragments de  code qui suivent à la filé .

public/js/grille.js
var articlesDataStore;
var articlesCols;
var articlesListGrid;
var articlesListWindow;

Ext.onReady(function(){
   Ext.QuickTips.init();

Dans ce bout de code nous avons déclarer les variables dont nous aurons besoin plus bas, si vous avez remarqué le code ExtJS commence toujours par Ext.OnReady,cette méthode nous assure que tous les éléments ont été chargé avant de commencer a exécuté les scripts.

Nous allons maintenant définir notre DataStore.

public/js/grille.js
articlesDataStore = new Ext.data.Store({
       id: 'articlesDataStore',
    proxy: new Ext.data.HttpProxy({       // on vas utiliser une requette Http
                url: 'index/grille',  //url de l'action qui gère notre grille
                method: 'POST'       //on va utiliser la méthode poste pour notre requette
    
            }),
       baseParams:{gAction: "gListe"},  //on défini les paramètre à transmettre au l'action
         reader: new Ext.data.JsonReader({   
         root: 'results',
         totalProperty: 'total',
         id: 'id'
       },
    [ 
         {name: 'ref', type: 'string', mapping: 'ref'},
         {name: 'designation', type: 'string', mapping: 'designation'},
         {name: 'Qte', type: 'int', mapping: 'Qte'},
         {name: 'Prix', type: 'float', mapping: 'Prix'},
         {name: 'famille', type: 'string', mapping: 'famille'},
   {name: 'Libelle', type: 'string', mapping: 'Libelle'},
         {name: 'date_ent', type: 'date', mapping: 'date_ent'}
         
       ]),
       
       sortInfo:{field: 'ref', direction: "ASC"}
    
     });

Nous avons déterminés ci-dessus le proxy, BaseParams, reader et la  définition des champs du DataStore dont:

Proxy : définit la méthode, url et le type de requête à transmettre à notre Action dans notre cas (POST, ‘index/grille’ et Http).

BaseParams : c’est les données qui seront transmise via la requête, dans notre cas nous envoyons une variable gAction avec la valeur gListe.

reader : définit la structure et lit les valeurs des données de retour transmises par l’action grille.

Attention la casse est respecté dans les noms de colonnes, le mapping doit être tel qu'il est définit dans votre base de données et le champ name au dataIndex du ColumnModel.

ColumnModel

dans le ColumnModel nous allons définir l’apparence et le comportement de chaque colonne de la grille

public/js/grille.js
  articlesCols = new Ext.grid.ColumnModel([
  {
   header: 'Ref.',
   readOnly: true,
   dataIndex: 'ref', 
   width: 60,
   hidden: false
  },
  {
   header: 'Désignation',
   readOnly: true,
   dataIndex: 'designation', 
   width: 200,
   hidden: false
  },
  {
   header: 'Qte',
   readOnly: true,
   dataIndex: 'Qte', 
   width: 50,
   align:'right',
   hidden: false
  },
  {
   header: 'Prix',
   readOnly: true,
   dataIndex: 'Prix', 
   width: 80,
   hidden: false,
   renderer: Ext.util.Format.formatNumber.createDelegate(Ext.util.Format),
            align:'right',
  
  },
  {
   header: 'Familles',
   readOnly: true,
   dataIndex: 'famille',
   width: 50,
   hidden: true
  },
  {
   header: 'Familles',
   readOnly: true,
   dataIndex: 'Libelle',
   width: 150,
   hidden: false
  },
  {
   header: 'Date d\'entrée',
   readOnly: true,
   dataIndex: 'date_ent', 
   width: 80,
   hidden: false,
   renderer:Ext.util.Format.dateRenderer('d/m/Y')
  }
  ]);

Malheureusement ExtJS 2.0 n’inclut pas de base un moyen de formatage pour les monétaires ou pour le groupage des numériques par millier, alors les membres de la communauté ExtJS on développé une extension qui nous permettra de formater notre colonne Prix.

lien de téléchargement de l’extension.

Nous  devrons mettre cette extension dans notre dossier js et insérer le script dans le l’entête de notre layout

Comme nous avons terminé de définir le DataStore et le ColumnModel, nous somme enfin prêts à créer notre grille, dans notre exemple nous avons choisi de mettre celle-ci dans une fenêtre flottante mais ce n’est pas une nécessité, vous la placer dans n’importe quel conteneur.  

public/js/grille.js
 
      articlesListGrid =  new Ext.grid.EditorGridPanel({
          id: 'articlesListGrid',
       title:'liste des employe',
          store: articlesDataStore,     // Définition du lien avec le DataStroe
       cm: articlesCols,        // affectation des colonnes  
       enableColLock:false,
       selModel: new Ext.grid.RowSelectionModel({singleSelect:false})

       });
       
  articlesListWindow = new Ext.Window({  //nous mettons notre grille dans une fenêtre flottante
      id: 'articlesListWindow',
      title: 'list articles',
      closable:true,
      width:700,
      height:350,
      plain:true,
      layout: 'fit',
     items: articlesListGrid  
    });
  
  articlesDataStore.load();
 
  articlesListWindow.show();   // Display our window
  
 
});

Nous avons terminé la conception de notre grille mais tous de même nous ne pourrons pas encore l’afficher, nous devons d’abord effectuer quelques modifications sur l’action grille de notre contrôleur Index comme nous l’avons prédis dans la première partie.

Application/Controllers/IndexController.php
    switch ($gAction) {
     case "gListe" :
       $data = array();
       $rows =$article->lister();
            foreach ($rows as  $key=>$row)
                    {
                     $date =new Zend_Date($rows[$key]['date_ent'] ,Zend_Date::ISO_8601);
                     $rows[$key]['date_ent'] =$date->toString('MM/dd/yyyy');
                    
                     }
        $data['results'] = $rows;
                          $data['total'] = count($rows);
                          $resultat = Zend_Json :: encode($data);
      break;

  

Nous avons défini ici la traitement à effectuer lorsque en reçoit la requête POST quand gAction = gListe comme suit.

  1. Récupération de la liste des articles.
  2. Conversion des dates du format MySQL en format JavaScript  YYYY-MM-DD =>  mm/dd/yyyy.
  3. encodé le tous en JSON.

Dans cette exemple nous avons défini tous les traitements dans notre action ce qui n’est pas très judicieux, le mieux est de définir des fonctions dans notre model auxquelles nous ferons appel pour mieux respecter le concept MVC et de décharger notre action pour une meilleur clarté de notre code.

Nous rajoutons maintenant la touche finale en appelons le script grille.js dans notre vue Index.

Application/views/scripts/index.phtml
<script type="text/javascript" src="<?php echo $this->baseUrl();?>/public/Js/grille.js"></script>

Nous arrivons a la fin de cette partie qui consiste à afficher la grille mais ce n’est pas encore fini, dans la partie suivante nous allons lui rajouter un peut de punch en lui ajoutant les fonctionnalités d’édition,d’ajout et de suppression.

dimanche 22 février 2009

Grille ExtJS et Zend Framework (1er Partie)

 
Préambule
Dans ce tutoriel nous allons réaliser une grille ExtJS dans le model MVC de Zend Framework en  corrélation avec Zend_Zb_Table,  celle-ci  ne va pas se contenté d’afficher nos données mais elle nous permettra aussi de modifier, ajouter, supprimer ou encore d’effectuer des recherches, entre autre elle sera doté d’une barre de pagination.
le présent tutoriel a été testé avec la version 1.7.4 de Zend Framework et de la version 2.0 d’ExtJS.
Comme cet article risque d’être un peut long nous allons le scinder en plusieurs parties.  
Pré-requis :
Nous supposons que vous avez  une assez bonne maitrise de PHP , du model MVC  de Zend Framework ainsi que des connaissances de base en Ajax.  
Mise en œuvre
Pour commencer nous allons créer un nouveau projet Zend Framework avec la structure conventionnel (voir ce tutoriel Débutez avec Zend Framework approche MVC) , acquérir et installer ExtJS comme décrit dans ce billet.
Base de données (conception).
Pour notre tutoriel nous prendrons comme exemple une liste d’articles en stock pour ce faite nous aurons besoin d’une base de données avec deux tables (articles et famille d’articles).
Table articles
Champs Type Commentaires
ref VARCHAR (20) PK Référence
designation VARCHAR(50) Désignation de l’article
qte INT(11) Quantité en stock
prix DOUBLE (14,2) Prix unitaire
famille INT code famille d’article
date_ent DATE date de 1er entrée

Table familles
Champs Type
id INT(11)
libelle VARCHAR(30)

le scripts ci-dessous va nous permettre de créer et ajouter quelques données exemple à nos deux tables .
Script sql
--
-- Structure de la table `articles`
--

CREATE TABLE IF NOT EXISTS `articles` (
  `ref` varchar(20) NOT NULL,
  `designation` varchar(50) NOT NULL,
  `Qte` int(11) NOT NULL,
  `Prix` double(14,2) NOT NULL,
  `famille` int(11) NOT NULL,
  `date_ent` date NOT NULL,
  PRIMARY KEY (`ref`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;

--
-- Contenu de la table `articles`
--

INSERT INTO `articles` (`ref`, `designation`, `Qte`, `Prix`, `famille`, `date_ent`) VALUES
('3112-0006', 'Enveloppes F25', 5, 20.00, 1, '2009-01-20'),
('3114-0001', 'Cartouche d''encre A45', 5, 200.00, 2, '2009-02-02'),
('3117-0007', 'lecteur DVD', 3, 1400.00, 3, '2009-02-20');

-- --------------------------------------------------------

--
-- Structure de la table `familles`
--

CREATE TABLE IF NOT EXISTS `familles` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `Libelle` varchar(30) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;

--
-- Contenu de la table `familles`
--

INSERT INTO `familles` (`id`, `Libelle`) VALUES
(1, 'Fournitures de bureau'),
(2, 'Consommables informatique'),
(3, 'Matériels informatique'),
(4, 'Pèces de rachange');
maintenant que notre base de données a été créer nous la allons nous connecter à celle-ci, dans votre bootstrap vous rajouter le fragment de code suivant.

Application\bootstrap.php.
 ....... 
 ......

$db = Zend_Db::factory('Pdo_Mysql', array(
    'host'     => 'localhost',
    'username' => 'root',
    'password' => '',
    'dbname'   => 'zfextjs'
));
Zend_Db_Table::setDefaultAdapter($db);
 ........
 ........
Nous avons utilisé cette méthode de connexion dans un but de simplicité n’étant pas la meilleur, nous vous conseillons d’utiliser un fichier de configuration distinct comme c’est défini dans  ce cours .Présentation du Zend Framework - Premiers pas. que je vous recommande fortement si vous ne l’avez pas déjà fait
Nous allons maintenant créer nos deux class qui vont encapsuler nos tables.
Application\models\Articles.php.
<?php
class Articles extends Zend_Db_Table {
 protected $_name = 'articles';
 protected $_primary = array ('ref' );
 
 public function lister() {
  $select = $this->select ();
  $select->from ( 'articles', '*' )
    ->setIntegrityCheck ( false )
    ->join ( 'familles', 'familles.id=articles.famille', 'Libelle' );
  return $this->fetchAll ( $select )->toArray();
 }

}
Application\models\Familles.php
class familles extends Zend_Db_Table
{
    protected $_familles = 'familles';
}
Maintenant nous allons nous intéresser à notre contrôleur, suivant l’action de l’utilisateur  notre grille envoi au contrôleur une requête post a travers un champs que nous allons nommé gAction et d’après ça valeur  nous déterminerons l’action à entreprendre sur notre base de données, nous définissons les valeur possible de gAction comme suit: 
  • gListe          : pour lister les données
  • gAjouter      : pour insérer un nouvel enregistrement.
  • gModifier     : pour modifier un enregistrement existant.
  • gSupprimer : pour supprimer un enregistrement
  • gChercher   : pour faire une recherche
Application\controllers\IndexController.php
 class IndexController extends Zend_Controller_Action {
 
 function indexAction() {
  $this->view->title = "liste des articles";
 
 }
 
 function grilleAction() {
  
  $this->_helper->layout->disableLayout ();
  $this->_helper->removeHelper ( 'viewRenderer' );
  
  if ($this->_request->isPost ()) {
   
   Zend_Loader::loadClass ( 'Zend_Filter_StripTags' );
   $f = new Zend_Filter_StripTags ( );
   $gAction = $f->filter ( $this->_request->getPost ( 'gAction' ) );
   if (! empty ( $gAction )) {
    
    $article = new Articles ();
    
    switch ($gAction) {
     case "gliste" :
      // Action lister....
      // $resultat = .....     
      break;
     case "gAjouter" :
      
      // $resultat = .....     
      break;
     case "gModifier" :
      //....
      

      break;
     case "gSupprimer" :
      
      break;
     case "gChercher" :
      
      break;
     default :
      break;
    }
    
    $this->getResponse ()->clearBody ();
    $this->getResponse ()->setHeader ( 'Content-Type', 'text/x-json' );
    $this->getResponse ()->setBody ( $resultat );
   }
  
  }
 }
}
c’est pas fini sinon ça sera trop beau, nous allons revenir plusieurs fois sur ce contrôleur afin de renseigner toutes les actions au fil de l’avancement du tutoriel. 
nous arrivons à la fin de cette première partie qui a consisté à préparer le Zend Framework à accueillir et répondre aux requêtes de notre grille  dans la second partie nous allons nous focaliser sur son affichage. 

lundi 16 février 2009

Authentification avec Zend_Auth et un formulaire ExtJS en MVC

Objectif :

Notre objectif dans ce tutoriel est de réaliser une authentification avec Zend_Auth et un formulaire ExtJS qui ressemblera  à ça:   

login

Pré-requis

Des connaissances en PHP, Zend Framework en particulier Zend_Auth et le model MVC sont fortement recommandé, pour avoir un aperçu je vous invite à suivre ces tutoriels.

dans ce tutoriel nous allons reprendre l’exemple Débutez avec Zend_Auth  qui explique très clairement comment fonctionne le processus d’authentification avec Zend_Auth et nous apporterons les modifications nécessaire pour qu’il puisse interagir avec notre formulaire AJAX.

Mise en œuvre

Pour arriver a notre but, nous aurons besoin de modifier le contrôleur et la vue d’authentification.

Le formulaire

Pour réaliser notre formulaire de login nous aurons besoin du Framework Ajax ExtJs que vous pouvez télécharger librement sur le  site officiel qui inclus une licence  open source selon l’usage

Lien de téléchargement ExtJS.

Une fois que vous avez téléchargé le Framework vous allons mettre celui-ci dans  dans le dossier prévu pour les scripts et nous allons créer un nouveau fichier login.js, à la fin votre dossier public aura la structure suivante:  

public

les fichiers styles.css et icon_padlock.png sont la juste pour définir l’icone (le petit cadenas) de la barre de titre de notre fenêtre.

icon_padlock icon_padlock.png

 

Public\css\styles.css
.image_login
{
padding-left:20px;
background:url(../images/icon_padlock.png) no-repeat 1px 0px;
}
.lbError
{
 color :red;
}

code css à rajouter a votre stylesheet.

 

public\js\login.js
Ext.onReady( function() {
 Ext.QuickTips.init();

 // Créer une variable qui va contenir notre FormPanel

  var login = new Ext.FormPanel( {
   labelWidth :80,
   url :'auth/login',
   frame :true,
   bodyStyle :'padding:5px;',
   defaultType :'textfield',
   monitorValid :true,
   // Création des deux champs nom d'utilisateur et mot de passe
   // la proprité name est celle qui est envoyez au serveur avec
   // la méthode POST.
   items : [ {
    fieldLabel :'Utilisateur',
    id :'username',
    name :'username',
    allowBlank :false
   }, {
    fieldLabel :'Mot de passe',
    id :'password',
    name :'password',
    inputType :'password',
    allowBlank :false
   }, {
    id :'lbError',
    name :'lbError',
    cls :'lbError',
    xtype :'label',
    text :'',
    width :160
   } ],

   buttons : [ {
    text :'Login',
    formBind :true,
    // Function lorsque en clique sur le boutton login
    handler : function() {

     login.getForm().submit(
       {
        method :'POST',
        waitTitle :'Conexion en cours...',
        waitMsg :'envoi des données...',
        
        success : function(form, action) {
         if (action && action.result) {
          var redirect = action.result.link;
          window.location = redirect;
         }
        },

        // en cas d'echec de l'autentification .
        // en renvois à l'utilisateur le motif

        failure : function(form, action) {

         login.getComponent('lbError').setText(
           action.result.msg.text);

         if (action.result.msg.code == '2') {
          login.getComponent('username').focus();
         } else if (action.result.msg.code == '3') {
          login.getComponent('password').focus();
         }

        }
       });
    }
   } ]
  });

  // ici on vas créer une fenetre qui va contenir Notre formPanel

  var win = new Ext.Window( {
   layout :'fit',
   title :'Identifiez vous',
   iconCls :'image_login',
   width :300,
   height :150,
   closable :false,
   resizable :false,
   modal :true,
   plain :true,
   border :false,
   items : [ login ]
  });
  win.show();
 });

 

Le but de ce tutoriel n’est pas de vous montrer comment créer une fiche avec ExtJS mais  de voir comment cette fiche va interagir avec l’action d’authentification, si vous voulez avoir plus de détails sur le code ci-dessus je vous recommande de jeter un œil à cet article et ce tutoriel (en anglais).

Néanmoins je tiens a vous expliquer ce qui ce passe lorsque on clique sur le bouton login.

Notre formulaire envoie une requête http  avec la méthode POST à l’url indiqué dans la première ligne mise en surbrillance (ligne 8) et attend au retour une réponse au format JSON sucess :true  ou sucess:false, nous incluons aussi d’autres informations tel que le lien de redirection en cas de succès  ou le text et le code de l’erreur dans la cas contraire.

affichage du formulaire

Pour pouvoir afficher notre formulaire nous devons initialiser le header de notre layout car vous aurais besoin peut être d’utiliser d’autres Widget ExtJs dans votre application.

Application\layouts\layout.phtml
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 Transitional//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
    <title><?php echo $this->escape($this->title); ?></title>
    <link rel="stylesheet" type="text/css" media="screen" href="<?php echo $this->baseUrl();?>/public/css/styles.css" />
    <link rel="stylesheet" type="text/css" href="<?php echo $this->baseUrl();?>/public/js/ext/resources/css/ext-all.css"> 
 <script type="text/javascript" src="<?php echo $this->baseUrl();?>/public/js/ext/adapter/ext/ext-base.js"></script>
 <script type="text/javascript" src="<?php echo $this->baseUrl();?>/public/js/ext/ext-all.js"></script>
</head>
<body>
<div id="content">
    <h1><?php echo $this->escape($this->title); ?></h1>
 
    <?php echo $this->layout()->content; ?>
</div>
</body>

ensuite dans l’action index de notre contrôleur auth nous affichons le formulaire

Application\views\scripts\auth\index.phtml
<script type="text/javascript" src="<?php echo $this->baseUrl();?>/Public/Js/login.js"></script>

Vous pouvez maintenant essayez d’afficher votre formulaire, si ce n’est pas le cas vous avez certainement loupé quelque chose.

Une fois que notre formulaire est terminé nous allons  nous intéressés au contrôleur qui va faire le plus gros du travail.

Application\controllers\AuthController.phtml
<?php
class AuthController extends Zend_Controller_Action {
 
 public function indexAction() {
  $this->view->headTitle ( 'Login' );
 }
 
 public function loginAction() {
  
  $this->_helper->layout->disableLayout ();
         $this->_helper->removeHelper('viewRenderer');
  
  if ($this->_request->isPost ()) {
   
   Zend_Loader::loadClass ( 'Zend_Filter_StripTags' );
   $f = new Zend_Filter_StripTags ( );
   $username = $f->filter ( $this->_request->getPost ( 'username' ) );
   $password = $f->filter ( $this->_request->getPost ( 'password' ) );
   
   if (empty ( $username )) {
    $message = "{success: false, errors: { reason: 'Please provide a username.' }}";
   
   } else {
    // setup Zend_Auth adapter for a database table
    Zend_Loader::loadClass ( 'Zend_Auth_Adapter_DbTable' );
    $dbAdapter = Zend_Registry::get ( 'dbAdapter' );
    $authAdapter = new Zend_Auth_Adapter_DbTable ( $dbAdapter );
    $authAdapter->setTableName ( 'users' );
    $authAdapter->setIdentityColumn ( 'username' );
    $authAdapter->setCredentialColumn ( 'password' );
    
    // Set the input credential values to authenticate against
    $authAdapter->setIdentity ( $username );
    $authAdapter->setCredential ( md5 ( $password ) );
    
    // do the authentication
    $auth = Zend_Auth::getInstance ();
    
    try {
     $result = $auth->authenticate ( $authAdapter );
     
     switch ($result->getCode ()) {
      case Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND :
       $message = "{success: false, msg: {text: 'Utilisateur non trouvé !', code: '2'}}";
       break;
      case Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID :
       $message = "{success: false, msg: {text: 'mot de passe incorect', code: '3'}}";
       break;
      case Zend_Auth_Result::SUCCESS :
       
       $data = $authAdapter->getResultRowObject ( null, 'password' );
       
       if ($data->UserLevel > 0) {
        $auth->getStorage ()->write ( $data );
        $message = "{success:true, link: '" . $this->_request->getBaseUrl () . "'}";
       
       } else {
        $result->auth->clearIdentity ();
        
        $message = "{success:false, msg: {text: 'non autoriser, code:'2'}}";
       }
       break;
     }
    
    } catch ( Zend_Db_Adapter_Exception $e ) {
     
     $message = "{success:false, msg: {text: 'Erreur de conexion, " . $e->getMessage () . "', code:'6'}}";
    } catch ( Zend_Exception $e ) {
     
     $message = "{success:false, msg: {text: 'Erreur Systeme, " . $e->getMessage () . "', code:'6'}}";
    }
    
    $this->getResponse ()->clearBody ();
    $this->getResponse ()->setHeader ( 'Content-Type', 'text/x-json' );
    $this->getResponse ()->setBody ( $message );
   
   }
  }
 
 }

}

Si nous regardons le code de près nous remarquerons  qu'il n'ya pas de grand changement par apport au contrôleur définit dans le tutoriel que je vous est cité au début de cet article.

 

Application\controllers\AuthController.phtml
$this->_helper->layout->disableLayout ();
$this->_helper->removeHelper('viewRenderer');

Comme nous l’avons dit précédemment la réponse attendu par notre formulaire doit être au format JSON et ne doit contenir aucun autre caractère, c’est à cet effet que nous devons désactiver le layout de l’action login et le rendu de la form pour évité d’inclure notre entête dans la réponse.

 

Application\controllers\AuthController.phtml
    switch ($result->getCode ()) {
      case Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND :
       $message = "{success: false, msg: {text: 'Utilisateur non trouvé !', code: '2'}}";
       break;
      case Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID :
       $message = "{success: false, msg: {text: 'mot de passe incorect', code: '3'}}";
       break;
      case Zend_Auth_Result::SUCCESS :
       
       $data = $authAdapter->getResultRowObject ( null, 'password' );
       
       if ($data->UserLevel > 0) {
        $auth->getStorage ()->write ( $data );
        $message = "{success:true, link: '" . $this->_request->getBaseUrl () . "'}";
       
       } else {
        $result->auth->clearIdentity ();
        
        $message = "{success:false, msg: {text: 'non autoriser, code:'2'}}";
       }
       break;
     }
    
    } catch ( Zend_Db_Adapter_Exception $e ) {
     
     $message = "{success:false, msg: {text: 'Erreur de conexion, " . $e->getMessage () . "', code:'6'}}";
    } catch ( Zend_Exception $e ) {
     
     $message = "{success:false, msg: {text: 'Erreur Systeme, " . $e->getMessage () . "', code:'6'}}";
    }

Dans cette partie nous créons notre chaine JSON selon la réponse de Zend_Auth.

la réponse prend le format {sucess:true, link:’url de redirection’} en cas de succès et {sucess:false,msg{text:’message d’erreur,code:’code erreur’}} en cas d’échec

 

Application\controllers\AuthController.phtml
$this->getResponse ()->clearBody ();
$this->getResponse ()->setHeader ( 'Content-Type', 'text/x-json' );
$this->getResponse ()->setBody ( $message );

et finalement nous envoyons la réponse à notre formulaire qui va nous rediriger vers l’url que nous lui avons indiqué ou nous affiche un message d’erreur et nous invite a s’authentifier à nouveau.

Vous pouvez télécharger le code source complet. de l’exemple.