Introduction au Zend Framework

 Apprendre Zend Framework

appendix

 Guide de référence Zend Framework


  •  Zend_Gdata
  •  Zend_Http
  •  Zend_InfoCard
  •  Zend_Json
  •  Zend_Layout
  •  Zend_Ldap
  •  Zend_Loader
  •  Zend_Locale
  •  Zend_Log
  •  Zend_Mail
  •  Zend_Markup
  •  Zend_Measure
  •  Zend_Memory
  •  Zend_Mime
  •  Zend_Navigation
  •  Zend_Oauth
  •  Zend_OpenId
  •  Zend_Paginator
  •  Zend_Pdf
  •  Zend_ProgressBar
  •  Zend_Queue
  •  Zend_Reflection
  •  Zend_Registry
  •  Zend_Rest

  •  Zend_Search_Lucene
  •  Zend_Serializer
  •  Zend_Server
  •  Zend_Service
  •  Zend_Session
  •  Zend_Soap
  •  Zend_Tag
  •  Zend_Test
  •  Zend_Text
  •  Zend_TimeSync
  •  Zend_Tool
  •  Zend_Tool_Framework
  •  Zend_Tool_Project
  •  Zend_Translate
  •  Zend_Uri
  •  Zend_Validate
  •  Zend_Version
  •  Zend_View
  •  Zend_Wildfire
  •  Zend_XmlRpc
  • ZendX_Console_Process_Unix
  • ZendX_JQuery
  • Translation 61.2% Update 2010-11-28 - Revision 23149 - Version ZF 1.11.x

    15.6. Authentification OpenID

    15.6.1. Introduction

    Zend_Auth_Adapter_OpenId permet l'authentification à travers un serveur distant OpenID. Une telle authentification attend que l'utilisateur fournisse à l'application Web son identifiant OpenID. L'utilisateur est alors redirigé vers un fournisseur de services OpenID, afin de s'identifier en rapport avec l'application Web utilisée. Un mot de passe ou un autre procédé est utilisé, et celui-ci n'est jamais connu de l'application Web originale.

    L'identité OpenID est juste une URI qui pointe vers une page avec des informations décrivant le serveur à utiliser et des informations sur l'utilisateur. Pour plus d'informations, consultez le site officiel OpenID.

    La classe Zend_Auth_Adapter_OpenId utilise Zend_OpenId_Consumer qui sert à gérer le protocole OpenID.

    [Note] Note

    Zend_OpenId utilise l'extension GMP, si disponible. L'utilisation de l'extension GMP est recommandée pour améliorer les performances de Zend_Auth_Adapter_OpenId.

    15.6.2. Spécifications

    Comme toute autre classe adaptateur de Zend_Auth, Zend_Auth_Adapter_OpenId implémente Zend_Auth_Adapter_Interface, qui définit une seule méthode : authenticate(). Elle est utilisée pour l'authentification elle-même, une fois que l'objet est prêt. La préparation d'un objet OpenID nécessite quelques options à passer à Zend_OpenId.

    A la différence des autres adaptateurs Zend_Auth, l'adaptateur Zend_Auth_Adapter_OpenId utilise une authentification sur un serveur externe à l'application, et nécessitera donc deux requêtes HTTP. Ainsi Zend_Auth_Adapter_OpenId::authenticate() devra être appelée deux fois : d'abord pour rediriger l'utilisateur vers le serveur OpenID (rien ne sera donc retourné par la méthode), qui lui-même redirigera l'utilisateur vers l'application, où un deuxième appel de méthode Zend_Auth_Adapter_OpenId::authenticate() vérifiera la signature et complétera le processus. Un objet Zend_Auth_Result sera alors cette fois-ci retourné.

    L'exemple suivant montre l'utilisation de Zend_Auth_Adapter_OpenId. Zend_Auth_Adapter_OpenId::authenticate() est appelée deux fois. La première fois juste après avoir envoyé le formulaire HTML, lorsque $_POST['openid_action'] vaut "login", et la deuxième fois après la redirection HTTP du serveur OpenID vers l'application, lorsque $_GET['openid_mode'] ou $_POST['openid_mode'] existe.

    <?php
    $status 
    "";
    $auth Zend_Auth::getInstance();
    if ((isset(
    $_POST['openid_action']) &amp;&amp;
         
    $_POST['openid_action'] == "login" &amp;&amp;
         !empty(
    $_POST['openid_identifier'])) ||
        isset(
    $_GET['openid_mode']) ||
        isset(
    $_POST['openid_mode'])) {
        
    $result $auth->authenticate(
            new 
    Zend_Auth_Adapter_OpenId(@$_POST['openid_identifier']));
        if (
    $result->isValid()) {
            
    $status "You are logged-in as "
                    
    $auth->getIdentity()
                    . 
    "<br>\n";
        } else {
            
    $auth->clearIdentity();
            foreach (
    $result->getMessages() as $message) {
                
    $status .= "$message<br>\n";
            }
        }
    } else if (
    $auth->hasIdentity()) {
        if (isset(
    $_POST['openid_action']) &amp;&amp;
            
    $_POST['openid_action'] == "logout") {
            
    $auth->clearIdentity();
        } else {
            
    $status "You are logged-in as "
                    
    $auth->getIdentity()
                    . 
    "<br>\n";
        }
    }
    ?>
    <html><body>
    <?php echo htmlspecialchars($status);?>
    <form method="post"><fieldset>
    <legend>OpenID Login</legend>

    <input type="text" name="openid_identifier" value="">
    <input type="submit" name="openid_action" value="login">
    <input type="submit" name="openid_action" value="logout">
    </fieldset></form></body></html>

    Il est possible de personnaliser le processus, pour par exemple demander une redirection du serveur OpenID vers l'application, sur une page différente de la première. Ceci peut être fait avec des objets personnalisés Zend_OpenId_Consumer_Storage ou Zend_Controller_Response. Vous pouvez aussi utiliser le procédé "Simple Registration" pour récupérer les informations au sujet de l'utilisateur, en provenance du serveur OpenID. Toutes ces possibilités sont écrites et détaillées dans le chapitre concernant Zend_OpenId_Consumer.

    digg delicious meneame google twitter technorati facebook

    Comments

    Loading...