Dalam perusahaan moden, pengesahan dan pengurusan identiti adalah sangat penting. Pengesahan identiti ialah cara penting untuk memastikan keselamatan dan kerahsiaan maklumat perusahaan. Di samping itu, melalui pengesahan identiti, perusahaan boleh mengawal akses pekerja kepada sistem dan aplikasi yang berbeza. Oleh itu, perusahaan memerlukan sistem pengurusan dan pengesahan identiti yang cekap, boleh dipercayai dan selamat.
LDAP (Lightweight Directory Access Protocol) ialah protokol terbuka yang digunakan untuk mengakses dan menyelenggara perkhidmatan direktori teragih. Direktori LDAP biasanya digunakan untuk menyimpan dan menerbitkan maklumat tentang ahli organisasi, sumber dan projek. Oleh itu, LDAP sangat sesuai untuk melaksanakan pengesahan dan pengurusan identiti peringkat perusahaan.
PHP ialah bahasa skrip yang digunakan secara meluas untuk pembangunan web. PHP mempunyai banyak kelebihan, seperti kemudahan pembelajaran dan penggunaan, sokongan yang meluas dan komuniti.
Artikel ini akan memperkenalkan cara menggunakan PHP dan LDAP untuk melaksanakan pengesahan dan pengurusan identiti peringkat perusahaan.
Langkah 1: Pasang sambungan LDAP
Sebelum anda bermula, anda perlu memasang sambungan LDAP untuk PHP. Anda boleh membuka sambungan dalam php.ini atau memuatkannya pada masa jalan menggunakan fungsi dl. Dalam sistem Linux, anda boleh memasang sambungan LDAP menggunakan arahan berikut:
sudo apt-get update sudo apt-get install php7.2-ldap
Langkah 2: Sambung ke pelayan LDAP
Sebelum menggunakan LDAP, anda perlu menyambung ke pelayan LDAP. Maklumat konfigurasi pelayan LDAP biasanya termasuk nama hos, port, nama pengguna dan kata laluan. Anda boleh menggunakan fungsi ldap_connect untuk menyambung ke pelayan LDAP.
$ldap_server = 'ldap://example.com'; $ldap_port = '389'; $ldap_user = 'cn=admin,dc=example,dc=com'; $ldap_password = 'password'; $ldap_connection = ldap_connect($ldap_server, $ldap_port); if ($ldap_connection) { $ldap_bind = ldap_bind($ldap_connection, $ldap_user, $ldap_password); if ($ldap_bind) { // Connection succeeded } else { // Connection failed } } else { // Connection failed }
Langkah Tiga: Pengesahan
Setelah disambungkan ke pelayan LDAP, anda boleh melakukan pengesahan. Pengesahan biasanya melibatkan membandingkan bukti kelayakan yang diberikan oleh pengguna dengan yang disimpan dalam direktori LDAP. Anda boleh menggunakan fungsi ldap_search untuk mencari maklumat pengguna dalam direktori LDAP, dan kemudian gunakan fungsi ldap_bind untuk mengikat bukti kelayakan pengguna untuk pengesahan.
$ldap_user_dn = 'uid=username,ou=people,dc=example,dc=com'; $ldap_user_password = 'password'; $ldap_search = ldap_search($ldap_connection, 'dc=example,dc=com', "(uid=username)"); $ldap_entries = ldap_get_entries($ldap_connection, $ldap_search); if ($ldap_entries['count'] == 1) { $ldap_user_dn = $ldap_entries[0]['dn']; $ldap_bind = ldap_bind($ldap_connection, $ldap_user_dn, $ldap_user_password); if ($ldap_bind) { // Authentication succeeded } else { // Authentication failed } } else { // Authentication failed }
Langkah Empat: Pengurusan Pengguna
Setelah disambungkan ke pelayan LDAP dan disahkan, anda boleh menguruskan pengguna dalam direktori LDAP menggunakan fungsi berikut:
$user_dn = 'cn=newuser,ou=people,dc=example,dc=com'; $user_info = array( 'cn' => 'newuser', 'sn' => 'user', 'uid' => 'newuser', 'userPassword' => '{SHA}pY4rqD0jmVv+YzgrxE9oqGCS74k=', 'objectClass' => array('top', 'person', 'organizationalPerson', 'inetOrgPerson') ); $ldap_add = ldap_add($ldap_connection, $user_dn, $user_info); if ($ldap_add) { // User added to LDAP directory } else { // User not added to LDAP directory }
ldap_unbind($ldap_connection);
Atas ialah kandungan terperinci Pengesahan dan pengurusan identiti peringkat perusahaan menggunakan PHP dan LDAP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!