Get display name for Zend LDAP Authentication

前端 未结 2 821
清酒与你
清酒与你 2021-01-23 23:34

I have successfully implemented the Zend Framework LDAP adapter for the Zend_Auth module, and can login against my Active Directory controller. However, the g

相关标签:
2条回答
  • 2021-01-23 23:43

    Well, I found out a way breaking out of the Zend_Auth module and using the Zend_Ldap module directly. If anyone knows how to do this using the Auth or AuthAdapter objects, I'd be glad to learn!

    I'm using Zend_Registry to store various LDAP options, and then the current user information:

    Login function:

    $authAdapter = new Zend_Auth_Adapter_Ldap(array(
        'server1' => array(
            'host' => Zend_Registry::get('LDAP_host'),
            'accountDomainName' => Zend_Registry::get('LDAP_domainName'),
            'accountCanonicalForm' => 2,
            'baseDn' => Zend_Registry::get('LDAP_baseDn'),
            'bindRequiresDn' => TRUE,
        )
    ));
    $authAdapter->setIdentity($_POST['username']);
    $authAdapter->setCredential($_POST['passwd']);
    $auth = Zend_Auth::getInstance();
    
    // Do the login
    $rs = $auth->authenticate($authAdapter);
    if (!$rs->isValid()) {
        // Login failed
        exit;
    }
    // Login succeeded
    

    Checking for authenticated user: If we are currently authenticated, create a Zend_Ldap object using similar options to the AuthAdapter, and search for this userid.

    $auth = Zend_Auth::getInstance();
    if ($auth->hasIdentity()) {
        $uid = $auth->getIdentity();
        Zend_Registry::set('cur_user', $uid); // Save username
        $ldap = new Zend_Ldap(array(
            'host' => Zend_Registry::get('LDAP_host'),
            'accountDomainName' => Zend_Registry::get('LDAP_domainName'),
            'accountCanonicalForm' => 2,
            'baseDn' => Zend_Registry::get('LDAP_baseDn'),
            'bindRequiresDn' => TRUE,
        ));
        $ldap->bind();
        $rs = $ldap->getEntry('uid='.$uid.','.Zend_Registry::get('LDAP_baseDn'), array('displayname', 'mail'));
        Zend_Registry::set('cur_user_name', $rs['displayname'][0]);
        Zend_Registry::set('cur_user_mail', $rs['mail'][0]);
    } else {
        Zend_Registry::set('cur_user', 'Anonymous');
        Zend_Registry::set('cur_user_name', 'Anonymous');
        Zend_Registry::set('cur_user_mail', 'nobody@nowhere.com');
    }
    
    0 讨论(0)
  • 2021-01-23 23:59

    Zend_Auth_Adapter_Ldap defines a method getAccountObject that will do what you want.

    eg;

    $adapter = new Zend_Auth_Adapter_Ldap($options, $username, $password);
    
    $result = $auth->authenticate($adapter);
    
    if ($result->isValid()) {
       $user_data = $adapter->getAccountObject();
    }
    

    The method allows you to optionally set which attributes you want to retrieve, too.

    0 讨论(0)
提交回复
热议问题