Bonjour à tous,
j'ai un petit problème avec mon formulaire de connexion. Quand je valide mon formulaire avec le champ login vide j'ai un message d'erreur qui s'affiche (Fatal error: Uncaught exception 'Zend_Controller_Dispatcher_Exception' with message 'Invalid controller specified (error)'), alors que quand je fais l'inverse je renseigne le champ login et je laisse vide le champ mot de passe, ma application me retourne bien qu'il y a un problème lors de l'authentification.
Voilà mon formulaire :
voila la vérification :Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39 class Application_Form_Connexion extends Zend_Form { public function init() { // attribut formulaire $this->setAction('index/test'); $this->setMethod('post'); $this->setAttrib('id', 'formulaireConnexion'); // username $username = new Zend_Form_Element_Text('username'); $username->setLabel('Login : '); $username->setRequired(true); // $username->addFilter('StripTags'); // $username->addFilter('StringTrim'); // $username->addValidator('NotEmpty'); // mot de passe $password = new Zend_Form_Element_Text('password'); $password->setLabel('Mot de passe : '); $password->setRequired(true); // $password->addFilter('StripTags'); // $password->addFilter('StringTrim'); // $password->addValidator('NotEmpty'); // bouton $connexion = new Zend_Form_Element_Submit('connexion'); $connexion->setAttrib('id', 'boutonConnexion'); // checkbox $checkbox = new Zend_Form_Element_Checkbox('checkbox'); $checkbox->setAttrib('id', 'checkboxConnexion'); $checkbox->setLabel('Garder ma session active'); // ajout $this->addElements(array($username, $password, $connexion, $checkbox)); } }
j'espère que j'ai été assez clair dans mon explication ;)Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43 public function testAction() { $db = Zend_Registry::get('db'); $tUser = new Application_Model_DbTable_TUser(); if($this->getRequest()->isPost()) { $data = $this->getRequest()->getPost(); $login = $data['username']; $mdp = $data['password']; // instanciation de Zend_Auth $auth = Zend_Auth::getInstance(); // charger et parametrer l'adapteur $dbAdapter = new Zend_Auth_Adapter_DbTable($db, 'user', 'loginUser', 'mdpUser'); // charger les crédits (login/mdp) à tester $dbAdapter->setIdentity($login); $dbAdapter->setCredential($mdp); // on teste l'authentification $res = $auth->authenticate($dbAdapter); if($res->isValid()) { // on récupère les infos de la personne après authentification $data = $dbAdapter->getResultRowObject(null, 'mdpUser'); // on stocke les données dans la session $auth->getStorage()->write($data); // on récupère le type d'utilisateur $typeUser = $data->typeUser; // redirection différente selon le type de l'utiliateur switch ($typeUser) { case 'administrateur': $this->_redirect('/administrateur/test/'); break; case 'drh': $this->_redirect('/drh/test/'); break; } } else { echo 'Erreur'; } } }
Merci d'avance pour votre future aide.