2017-07-03 250 views
0

是否可以显示登录后身份验证的人员?PHP LDAP身份验证为

我的代码包含登录和工作:

HTML:

<form action="index.php" method="POST"> 
    User: 
    <input type="text" name="username" /><br> 
    Pwd: 
    <input type="password" name="password" /><br> 
    <input type="submit" value="Login"> 
</form> 

PHP:

<?php 

$ldapServer = 'ldap://myServer'; 
$ldapPort = myPort; 
$username = $_POST['username']."@myDomain.local"; 
$password = $_POST['password']; 

$connect = ldap_connect($ldapServer, $ldapPort) or die("Connection failed!."); 
ldap_set_option($connect, LDAP_OPT_PROTOCOL_VERSION, 3); 
ldap_set_option($connect, LDAP_OPT_REFERRALS, 0); 

if (@ldap_bind($connect, $username, $password)) { 
    echo "Authenticated"; 
} 
else { 
    echo "Wrong Username or Password"; 
} 

当我开始LDP.EXE PROGRAMM它让我看到 自民党。 exe:

0 = ldap_set_option(ld, LDAP_OPT_ENCRYPT, 1) 
res = ldap_bind_s(ld, NULL, &NtAuthIdentity, NEGOTIATE (1158)); // v.3 
    {NtAuthIdentity: User='myUserName'; Pwd=<unavailable>; domain = 'myDomain.local'} 
Authenticated as: 'MYDOMAIN\myUser'. 

问题是我如何提取并将其呈现给我正确身份验证的html页面。

+0

当然,你可以只'回声$ username'显示谁是登录的代码?将该值存储在'$ _SESSION'中以在其他页面中引用它。 – timclutton

回答

0

备案:解决我的问题: 我把之间的if语句

$filter = "(samAccountName=$user)"; 
    $search = ldap_search($connect, $base_dn, $filter); 
    $info = ldap_get_entries($connect, $search); 
    echo "Logged In"; 
    for($i=0; $i<$info["count"]; $i++) { 
     if($info['count'] > 1) break; 
     echo "<p>Hello, <strong> ". $info[$i]["sn"][0] .", " . $info[$i]["givenname"][0] ."</strong><br /> (" . $info[$i]["samaccountname"][0] .")</p>\n"; 
    }