Posted under » PHP on 25 October 2015
You must have PHP5 LDAP installed before this can work.
Using LDAP bind is the basic LDAP tool.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | $ldaprdn = 'hanafi@astar.edu.sg' ; // ldap rdn or dn $ldappass = 'MrLKYisUgly' ; // associated password // connect to ldap server $ldapconn = ldap_connect( "108.80.70.5" ) or die ( "Could not connect to LDAP server." ); if ( $ldapconn ) { // binding to ldap server $ldapbind = ldap_bind( $ldapconn , $ldaprdn , $ldappass ); // verify binding if ( $ldapbind ) { echo "LDAP bind successful..." ; } else { echo "LDAP bind failed..." ; } } |
In most cases, you need to define more things.
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 | <¿php $ldap_host = "ldap.php.net.sg" ; $ldap_port = "389" ; $base_dn = "dc=php,dc=net,dc=sg" ; $filter = "(cn=hanafi)" ; $ldap_user = "cn=hanafi,ou=people,dc=php,dc=net,dc=sg" ; $ldap_pass = "taik" ; $connect = ldap_connect( $ldap_host , $ldap_port ) or exit ( ">>Could not connect to LDAP server<<" ); ldap_set_option( $connect , LDAP_OPT_PROTOCOL_VERSION, 3); ldap_set_option( $connect , LDAP_OPT_REFERRALS, 0); $bind = ldap_bind( $connect , $ldap_user , $ldap_pass ) or exit ( ">>Could not bind to $ldap_host<<" ); $read = ldap_search( $connect , $base_dn , $filter ) or exit ( ">>Unable to search ldap server<<" ); $info = ldap_get_entries( $connect , $read ); echo $info [ "count" ]. " entries returned<p>" ; $ii =0; for ( $i =0; $ii < $info [ $i ][ "count" ]; $ii ++){ $data = $info [ $i ][ $ii ]; echo $data . ": " . $info [ $i ][ $data ][0]. "<br>" ; } ldap_close( $connect ); ?> </p> |
Another way. This time without password or anonymous connect.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <¿php // LDAP variables $ldap_host = "ldap.php.net.sg" ; $ldap_port = "389" ; // Connecting to LDAP $connection = ldap_connect( $ldaphost , $ldapport ) or die ( "Could not connect to $ldaphost" ); $bind = ldap_bind( $connection ); $query = ldap_search( $connection , 'ou=zgroups,dc=ldap,dc=php,dc=net' , 'cn=all' ); $query_result = ldap_get_entries( $connection , $query ); for ( $k =0; $k < $query_result [0][ "uniquemember" ][ "count" ]; $k ++) { echo $query_result [0][ "uniquemember" ][ $k ]. " -<br>" ; } ldap_close( $connection ); ?> |
If you have just updated your OpenLDAP, you must connect using the V3 protocol or you will get this error. This function is only available when using OpenLDAP 2.x.x OR Netscape Directory SDK x.x.
1 | ldap error log: conn=1482 op=0 RESULT tag=97 err=2 text=historical protocol version requested, use LDAPv3 instead |
Then add the set_option thingie. This is also shown above on the first LDAP connect example.
1 2 3 4 5 6 7 8 | // LDAP variables $ldap_host = "ldap.php.net.sg" ; $ldap_port = "389" ; // Connecting to LDAP $connection = ldap_connect( $ldaphost , $ldapport ) or die ( "Could not connect to $ldaphost" ); ldap_set_option( $connection , LDAP_OPT_PROTOCOL_VERSION, 3); |