當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ldap_free_result函數代碼示例

本文整理匯總了PHP中ldap_free_result函數的典型用法代碼示例。如果您正苦於以下問題:PHP ldap_free_result函數的具體用法?PHP ldap_free_result怎麽用?PHP ldap_free_result使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了ldap_free_result函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: search_uidspip

function search_uidspip ($filter,$ldap_server, $ldap_port, $dn) {
  global  $ldap_grp_attr;
  
  // LDAP attributs
  $ldap_grp_attr = array (
    "cn",
    "memberuid"  );

  $ds = @ldap_connect ( $ldap_server, $ldap_port );
  if ( $ds ) {
    $r = @ldap_bind ( $ds ); // Bind anonyme
    if ($r) {
      $result=@ldap_list ($ds, $dn["groups"], $filter, $ldap_grp_attr);
      if ($result) {
        $info = ldap_get_entries( $ds, $result );
        if ($info["count"]) {
          // Stockage des logins des membres des classes
          //  dans le tableau $ret
          $init=0;
          for ($loop=0; $loop < $info["count"]; $loop++) {
            $group=split ("[\_\]",$info[$loop]["cn"][0],2);
            for ( $i = 0; $i < $info[$loop]["memberuid"]["count"]; $i++ ) {
              $ret[$init]["uid"] = $info[$loop]["memberuid"][$i];
              $ret[$init]["cat"] = $group[0];
              $init++;
            }
          }
        }
        ldap_free_result ( $result );
      }
    } 
    @ldap_close ( $ds );
  } 
  return $ret;
}
開發者ID:rhertzog,項目名稱:lcs,代碼行數:35,代碼來源:accorder_comptes_lcs.php

示例2: checkGroupMembership

 /**
  * Validate group membership
  *
  * Searches the LDAP server for group membership of the
  * supplied username.  Quotes all LDAP filter meta characters in
  * the user name before querying the LDAP server.
  *
  * @param  string Distinguished Name of the authenticated User
  * @return boolean
  */
 public function checkGroupMembership($user)
 {
     if (!is_resource($this->_resource)) {
         $this->connect();
     }
     $userDn = $this->_getAccountDn($user);
     foreach ($this->_options['groups'] as $group) {
         // make filter
         $filter = sprintf('(&(%s=%s)(%s=%s)%s)', $this->_options['groupAttr'], $group, $this->_options['memberAttr'], $this->_quoteFilterString($userDn), $this->_options['groupFilter']);
         // make search base dn
         $search_basedn = $this->_options['groupDn'];
         if ($search_basedn != '' && substr($search_basedn, -1) != ',') {
             $search_basedn .= ',';
         }
         $search_basedn .= $this->_options['baseDn'];
         $func_params = array($this->_resource, $search_basedn, $filter, array($this->_options['memberAttr']));
         $func_name = 'ldap_search';
         //echo "Searching with $func_name and filter $filter in $search_basedn";
         // search
         if (($result_id = @call_user_func_array($func_name, $func_params)) != false) {
             if (@ldap_count_entries($this->_resource, $result_id) == 1) {
                 @ldap_free_result($result_id);
                 //echo 'User is member of group';
                 return true;
             }
         }
     }
     // default
     throw new Zend_Ldap_Exception(null, 'User is NOT member of any group!', BDBLdap::LDAP_USER_NOT_MEMBER_OF_GROUP);
     return false;
 }
開發者ID:Tony133,項目名稱:zf-web,代碼行數:41,代碼來源:BDBLdap.php

示例3: login

 function login($uid, $pwd, $ip = 0)
 {
     $this->groups = array();
     $this->uid = $uid;
     if (!($ds = ldap_connect($this->host))) {
         return false;
     }
     if (!($r = @ldap_bind($ds, "uid={$uid},{$this->basedn}", $pwd))) {
         ldap_unbind($ds);
         sess_log(LOG_LOGIN, 0, "uid={$uid},{$this->basedn}", 0);
         return false;
     }
     $filter = "(&(objectclass=posixGroup)(memberuid={$uid}))";
     $retvals = array("cn");
     $sr = ldap_search($ds, $this->basedn, $filter, $retvals);
     $entries = ldap_get_entries($ds, $sr);
     $this->groups = array();
     for ($i = 0; $i < $entries["count"]; $i++) {
         for ($j = 0; $j < $entries[$i]["cn"]["count"]; $j++) {
             $this->groups[] = $entries[$i]["cn"][$j];
         }
     }
     ldap_free_result($sr);
     ldap_unbind($ds);
     //	print_r( $this->groups );
     sess_log(LOG_LOGIN, 0, "uid={$uid},{$this->basedn}", 1);
     return true;
 }
開發者ID:BackupTheBerlios,項目名稱:dilps,代碼行數:28,代碼來源:authLDAP2307User.class.php

示例4: _free

 /**
  * free and close the bound ressources
  */
 function _free()
 {
     if (isset($this->_sr) and is_resource($this->_sr)) {
         ldap_free_result($this->_sr);
     }
     if (isset($this->_ldap) and is_resource($this->_ldap)) {
         ldap_close($this->_ldap);
     }
     unset($this->_sr);
     unset($this->_ldap);
 }
開發者ID:hugcoday,項目名稱:wiki,代碼行數:14,代碼來源:LDAP.php

示例5: studentid2uid

 public function studentid2uid($pStudentId)
 {
     if (empty($pStudentId)) {
         throw new Exception("No parameter given", E_PARAM);
     }
     $dn = LDAP_OU . ", " . LDAP_O . ", " . LDAP_C;
     $filter = "(&(objectclass=" . LDAP_OBJECTCLASS_STUDENT . ")(" . LDAP_ATTRIBUTE_STUDID . "=" . $pStudentId . "))";
     $search = ldap_search($this->ldap_conn, $dn, $filter, array("uid"));
     $entry = ldap_first_entry($this->ldap_conn, $search);
     $result = @ldap_get_values($this->ldap_conn, $entry, "uid");
     ldap_free_result($search);
     return $result[0];
 }
開發者ID:rolwi,項目名稱:koala,代碼行數:13,代碼來源:lms_ldap.class.php

示例6: __destruct

 public function __destruct()
 {
     $con = $this->connection->getResource();
     $this->connection = null;
     if (null === $this->search || false === $this->search) {
         return;
     }
     $success = ldap_free_result($this->search);
     $this->search = null;
     if (!$success) {
         throw new LdapException(sprintf('Could not free results: %s', ldap_error($con)));
     }
 }
開發者ID:symfony,項目名稱:ldap,代碼行數:13,代碼來源:Query.php

示例7: ldapSearchUser

function ldapSearchUser($filter, $required)
{
    global $AUTHCFG;
    $conn = ldapConnectServer();
    if ($conn == NULL) {
        return NULL;
    }
    $ident = @ldap_search($conn, $AUTHCFG['ldap_basedn'], $filter, $required);
    if ($ident) {
        $result = ldap_get_entries($conn, $ident);
        ldap_free_result($ident);
    }
    ldap_unbind($conn);
    return $result;
}
開發者ID:braybaut,項目名稱:ldap-vtiger,代碼行數:15,代碼來源:Ldap.php

示例8: execute

 /**
  * {@inheritdoc}
  */
 public function execute(LdapOperationInterface $operation)
 {
     $allEntries = [];
     /** @var QueryOperation $operation */
     $this->paging()->setIsEnabled($this->shouldUsePaging($operation));
     $this->paging()->start($operation->getPageSize(), $operation->getSizeLimit());
     do {
         $this->paging()->next();
         $result = @call_user_func($operation->getLdapFunction(), $this->connection->getConnection(), ...$operation->getArguments());
         $allEntries = $this->processSearchResult($result, $allEntries);
         $this->paging()->update($result);
     } while ($this->paging()->isActive());
     $this->paging()->end();
     @ldap_free_result($result);
     return $allEntries;
 }
開發者ID:ldaptools,項目名稱:ldaptools,代碼行數:19,代碼來源:QueryOperationHandler.php

示例9: getValuesFromCas

 public function getValuesFromCas($cas)
 {
     $result = ldap_search($this->conn, "ou=People,o=cwru.edu,o=isp", "uid=" . $cas);
     if ($entries = ldap_first_entry($this->conn, $result)) {
         $firstName = ldap_get_values($this->conn, $entries, "givenName");
         $surname = ldap_get_values($this->conn, $entries, "SN");
         $mail = ldap_get_values($this->conn, $entries, "mail");
         ldap_free_result($result);
         $return['firstName'] = $firstName[0];
         $return['lastName'] = $surname[0];
         $return['mail'] = $mail[0];
         return $return;
     } else {
         return false;
     }
 }
開發者ID:nagyistoce,項目名稱:moodle-Teach-Pilot,代碼行數:16,代碼來源:class.ldap.php

示例10: search

 public function search(array $params)
 {
     $this->connect();
     $ref = array('base_dn' => '', 'filter' => '');
     if (count($diff = array_diff_key($ref, $params))) {
         throw new \Exception(sprintf('You must defined %s', print_r($diff, true)));
     }
     $attrs = isset($params['attrs']) ? $params['attrs'] : array();
     $this->info(sprintf('ldap_search base_dn %s, filter %s', print_r($params['base_dn'], true), print_r($params['filter'], true)));
     $search = @ldap_search($this->ress, $params['base_dn'], $params['filter'], $attrs);
     $this->checkLdapError();
     if ($search) {
         $entries = ldap_get_entries($this->ress, $search);
         @ldap_free_result($search);
         return is_array($entries) ? $entries : false;
     }
     return false;
 }
開發者ID:pedroresende,項目名稱:LdapBundle,代碼行數:18,代碼來源:LdapConnection.php

示例11: find

 /**
  * {@inheritdoc}
  */
 public function find($dn, $query, $filter = '*')
 {
     if (!is_array($filter)) {
         $filter = array($filter);
     }
     $search = ldap_search($this->connection, $dn, $query, $filter);
     if (false === $search) {
         throw new LdapException(ldap_error($this->connection));
     }
     $infos = ldap_get_entries($this->connection, $search);
     if (false === @ldap_free_result($search)) {
         throw new LdapException(ldap_error($this->connection));
     }
     if (0 === $infos['count']) {
         return;
     }
     return $infos;
 }
開發者ID:WilBenShu,項目名稱:digital_pilot,代碼行數:21,代碼來源:LdapClient.php

示例12: phamm_search

 /**
  * Generic LDAP search
  *
  * @author Alessandro De Zorzi <adezorzi@rhx.it>
  *
  * @todo add attrsonly, sizelimit, timelimit
  *
  * @param string $base_dn
  * @param string $filter
  * @param array $attributes
  * @return array $entries
  **/
 static function phamm_search($base_dn, $filter, $attributes = null, $sort = null)
 {
     global $connect;
     // Do a LDAP search
     if (isset($attributes)) {
         $search = ldap_search($connect, $base_dn, $filter, $attributes);
     } else {
         $search = ldap_search($connect, $base_dn, $filter);
     }
     // Order the results if possible
     if (version_compare(phpversion(), "4.2.0", ">=")) {
         ldap_sort($connect, $search, $sort);
     }
     // Get entries
     $entries = ldap_get_entries($connect, $search);
     // Free the memory
     ldap_free_result($search);
     // Return the entry
     return $entries;
 }
開發者ID:steveblamey,項目名稱:phamm,代碼行數:32,代碼來源:ldap.php

示例13: ldap_authenticate

function ldap_authenticate($user_id, $password)
{
    $ldap_server = LDAP_SERVER;
    $ldap_port = LDAP_PORT;
    $ldap_id = LDAP_ID;
    $ldap_pwd = LDAP_PWD;
    $ldap_root_dn = LDAP_DN;
    $ldap_proto = LDAP_PROTOCOL;
    //$ldap_user = '(&(lmaccessstatusid=active)(uid=' . $user_id . '))';
    $ldap_user = '(uid=' . $user_id . ')';
    $ldapconn = ldap_connect($ldap_server, $ldap_port);
    if (!$ldapconn) {
        error_report_show("login.php", LDAP_CONNECTION_FAILED);
    }
    if (!ldap_set_option($ldapconn, LDAP_OPT_PROTOCOL_VERSION, $ldap_proto)) {
        error_report_show("login.php", LDAP_CONNECTION_FAILED);
    }
    $ldapbind = ldap_bind($ldapconn, $ldap_id, $ldap_pwd);
    if (!$ldapbind) {
        error_report_show("login.php", INVALID_LOGIN);
    }
    $ldapsearch = ldap_search($ldapconn, $ldap_root_dn, $ldap_user);
    $ldapentries = ldap_get_entries($ldapconn, $ldapsearch);
    $authenticated = false;
    if ($ldapentries) {
        # Try to authenticate to each until we get a match
        for ($i = 0; $i < $ldapentries['count']; $i++) {
            $dn = $ldapentries[$i]['dn'];
            # Attempt to bind with the DN and password
            if (@ldap_bind($ldapconn, $dn, $password)) {
                $authenticated = true;
                break;
            }
        }
    }
    ldap_close($ldapconn);
    ldap_free_result($ldapsearch);
    return $authenticated;
}
開發者ID:nourchene-benslimane,項目名稱:rth_backup,代碼行數:39,代碼來源:ldap_api.php

示例14: getChildrenDns

 /**
  * Retrieve the immediate children DNs of the given $parentDn
  *
  * This method is used in recursive methods like {@see delete()}
  * or {@see copy()}
  *
  * @param  string|Dn $parentDn
  * @throws Exception\LdapException
  * @return array of DNs
  */
 protected function getChildrenDns($parentDn)
 {
     if ($parentDn instanceof Dn) {
         $parentDn = $parentDn->toString();
     }
     $children = array();
     ErrorHandler::start(E_WARNING);
     $search = ldap_list($this->getResource(), $parentDn, '(objectClass=*)', array('dn'));
     for ($entry = ldap_first_entry($this->getResource(), $search); $entry !== false; $entry = ldap_next_entry($this->getResource(), $entry)) {
         $childDn = ldap_get_dn($this->getResource(), $entry);
         if ($childDn === false) {
             ErrorHandler::stop();
             throw new Exception\LdapException($this, 'getting dn');
         }
         $children[] = $childDn;
     }
     ldap_free_result($search);
     ErrorHandler::stop();
     return $children;
 }
開發者ID:Rovak,項目名稱:zf2,代碼行數:30,代碼來源:Ldap.php

示例15: getUserData

 /**
  * Return user info
  *
  * Returns info about the given user needs to contain
  * at least these fields:
  *
  * name string  full name of the user
  * mail string  email addres of the user
  * grps array   list of groups the user is in
  *
  * This LDAP specific function returns the following
  * addional fields:
  *
  * dn     string  distinguished name (DN)
  * uid    string  Posix User ID
  * inbind bool    for internal use - avoid loop in binding
  *
  * @author  Andreas Gohr <andi@splitbrain.org>
  * @author  Trouble
  * @author  Dan Allen <dan.j.allen@gmail.com>
  * @author  <evaldas.auryla@pheur.org>
  * @author  Stephane Chazelas <stephane.chazelas@emerson.com>
  * @return  array containing user data or false
  */
 function getUserData($user, $inbind = false)
 {
     global $conf;
     if (!$this->_openLDAP()) {
         return false;
     }
     // force superuser bind if wanted and not bound as superuser yet
     if ($this->cnf['binddn'] && $this->cnf['bindpw'] && $this->bound < 2) {
         // use superuser credentials
         if (!@ldap_bind($this->con, $this->cnf['binddn'], $this->cnf['bindpw'])) {
             if ($this->cnf['debug']) {
                 msg('LDAP bind as superuser: ' . htmlspecialchars(ldap_error($this->con)), 0, __LINE__, __FILE__);
             }
             return false;
         }
         $this->bound = 2;
     } elseif ($this->bound == 0 && !$inbind) {
         // in some cases getUserData is called outside the authentication workflow
         // eg. for sending email notification on subscribed pages. This data might not
         // be accessible anonymously, so we try to rebind the current user here
         $pass = PMA_blowfish_decrypt($_SESSION[DOKU_COOKIE]['auth']['pass'], auth_cookiesalt());
         $this->checkPass($_SESSION[DOKU_COOKIE]['auth']['user'], $pass);
     }
     $info['user'] = $user;
     $info['server'] = $this->cnf['server'];
     //get info for given user
     $base = $this->_makeFilter($this->cnf['usertree'], $info);
     if (!empty($this->cnf['userfilter'])) {
         $filter = $this->_makeFilter($this->cnf['userfilter'], $info);
     } else {
         $filter = "(ObjectClass=*)";
     }
     $sr = $this->_ldapsearch($this->con, $base, $filter, $this->cnf['userscope']);
     $result = @ldap_get_entries($this->con, $sr);
     if ($this->cnf['debug']) {
         msg('LDAP user search: ' . htmlspecialchars(ldap_error($this->con)), 0, __LINE__, __FILE__);
         msg('LDAP search at: ' . htmlspecialchars($base . ' ' . $filter), 0, __LINE__, __FILE__);
     }
     // Don't accept more or less than one response
     if (!is_array($result) || $result['count'] != 1) {
         return false;
         //user not found
     }
     $user_result = $result[0];
     ldap_free_result($sr);
     // general user info
     $info['dn'] = $user_result['dn'];
     $info['gid'] = $user_result['gidnumber'][0];
     $info['mail'] = $user_result['mail'][0];
     $info['name'] = $user_result['cn'][0];
     $info['grps'] = array();
     // overwrite if other attribs are specified.
     if (is_array($this->cnf['mapping'])) {
         foreach ($this->cnf['mapping'] as $localkey => $key) {
             if (is_array($key)) {
                 // use regexp to clean up user_result
                 list($key, $regexp) = each($key);
                 if ($user_result[$key]) {
                     foreach ($user_result[$key] as $grp) {
                         if (preg_match($regexp, $grp, $match)) {
                             if ($localkey == 'grps') {
                                 $info[$localkey][] = $match[1];
                             } else {
                                 $info[$localkey] = $match[1];
                             }
                         }
                     }
                 }
             } else {
                 $info[$localkey] = $user_result[$key][0];
             }
         }
     }
     $user_result = array_merge($info, $user_result);
     //get groups for given user if grouptree is given
     if ($this->cnf['grouptree'] || $this->cnf['groupfilter']) {
//.........這裏部分代碼省略.........
開發者ID:kosenconf,項目名稱:kcweb,代碼行數:101,代碼來源:ldap.class.php


注:本文中的ldap_free_result函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。