LDAP (Lightweight Directory Access Protocol) ialah protokol rangkaian biasa yang digunakan untuk mengakses dan mengurus perkhidmatan direktori. Dalam pembangunan bahasa PHP, LDAP sering digunakan untuk berinteraksi dengan perkhidmatan direktori LDAP luaran, seperti pengesahan identiti dan kebenaran pengguna. Walau bagaimanapun, disebabkan sifat LDAP, ia juga mempunyai beberapa kelemahan keselamatan, seperti isu suntikan LDAP dan penggantian LDAP. Artikel ini akan meneroka cara untuk mengelakkan kelemahan berkaitan LDAP dalam pembangunan bahasa PHP.
Suntikan LDAP ialah kelemahan keselamatan yang biasa, serupa dengan suntikan SQL. Penyerang boleh memintas pengesahan dan kawalan akses dengan memalsukan rentetan pertanyaan LDAP, dengan itu mendapat akses kepada data direktori yang tidak dibenarkan.
Untuk mengelakkan suntikan LDAP, kita harus menggunakan pernyataan pertanyaan LDAP berparameter. Khususnya, kita harus menggunakan penapis LDAP dan input berparameter untuk membina pertanyaan LDAP. Contohnya, kod berikut menunjukkan pertanyaan pengesahan LDAP yang mudah:
$ldap_dn = "cn=".$_POST['username'].",ou=people,dc=example,dc=com"; $ldap_password = $_POST['password']; $ldap_con = ldap_connect("ldap.example.com"); ldap_bind($ldap_con, $ldap_dn, $ldap_password);
Kod di atas mengandungi dua pembolehubah, $ldap_dn dan $ldap_password. $ldap_dn ialah rentetan pertanyaan LDAP yang dibina daripada nama pengguna yang dimasukkan oleh pengguna. $ldap_password ialah kata laluan yang dimasukkan oleh pengguna. Penyerang boleh cuba memintas pengesahan dengan membina nama pengguna berniat jahat untuk memalsukan $ldap_dn. Contohnya, jika nama pengguna yang dibina oleh penyerang ialah "admin)(&(password=", kod di atas akan menanyakan sesuatu seperti "cn=admin)(&(password=,ou=people, dc= example,dc=com" rentetan LDAP, dengan itu berpotensi mengakses data direktori yang tidak dibenarkan.
Untuk mengelakkan suntikan LDAP, kita harus membina rentetan pertanyaan LDAP menggunakan input berparameter. Khususnya, kita boleh menggunakan fungsi ldap_escape() untuk escape input pengguna. Kod berikut menunjukkan pertanyaan pengesahan LDAP menggunakan fungsi ldap_escape():
$username = $_POST['username']; $password = $_POST['password']; $ldap_dn = "cn=".ldap_escape($username, "", LDAP_ESCAPE_FILTER).",ou=people,dc=example,dc=com"; $ldap_password = $password; $ldap_con = ldap_connect("ldap.example.com"); ldap_bind($ldap_con, $ldap_dn, $ldap_password);
Dalam kod di atas, kami menggunakan fungsi ldap_escape() untuk melepaskan $username, Ini kemudiannya digunakan untuk membina $ ldap_dn. Ini memastikan $ldap_dn hanya mengandungi aksara LDAP yang sah, menghalang penyerang daripada memalsukan $ldap_dn dengan membina nama pengguna berniat jahat untuk mengelakkan LDAP ditulis ganti
$ldap_username = "readonly_user"; $ldap_password = "password"; $ldap_con = ldap_connect("ldap.example.com"); ldap_set_option($ldap_con, LDAP_OPT_PROTOCOL_VERSION, 3); ldap_start_tls($ldap_con); ldap_bind($ldap_con, $ldap_username, $ldap_password);
Atas ialah kandungan terperinci Bagaimana untuk mengelakkan kelemahan berkaitan LDAP dalam pembangunan bahasa PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!