天天看點

PHP 擷取LDAP伺服器Schema資料

最近工作中一直在與LDAP打交道,在官方推薦的​​client-apis​​裡,可以很容易找到每個語言對應的API,進而與LDAP伺服器互動。但是在用​​ApacheDirectoryStudio​​時,這個軟體竟然能展示Schema資料,然後認真看了下官方文檔,還是沒看到有說明查詢Schema資料的地方(如果有小夥伴在文檔中看到相關說明,希望能留言告訴我)。但是找到了用php寫的用戶端phpLDAPAdmin,随後通過其源碼,發現了如何查詢Schema資料。

通過官方文檔,我們查到Schema資料包含下面四個部分

  • syntaxes
  • attributes
  • matching_rules
  • objectclasses

以查詢objectclasses為例(也可以一次性查詢),其對應的查詢方法如下

第一種情況

$read_ret = ldap_read($ds, 'cn=Subschema', '(objectClass=subschema)', ['objectclasses']);
$read_ret = ldap_read($ds, 'cn=Subschema', '(objectClass=*)', ['objectclasses']);
      

如果第一種查詢不到,則用第二種

$read_ret = ldap_read($ds, 'cn=Aggregate,cn=Schema,cn=configuration,dc=example,dc=com', '(objectClass=*)';
$read_ret = ldap_read($ds, 'cn=Schema,cn=configuration,dc=example,dc=com', '(objectClass=*)', ['objectclasses']);
$read_ret = ldap_read($ds, 'cn=Schema,ou=Admin,dc=example,dc=com', '(objectClass=*)', ['objectclasses']);
      

如果第二種查詢不到,則用第三種

$read_ret = ldap_read($ds, 'cn=schema,cn=config', '(objectClass=*)', ['objectclasses']);