ldap协议本身不支持单次请求删除多个dn,因此php中必须通过循环调用ldap_delete逐一删除;本文详解该限制的根源、安全高效的实现方式及关键注意事项。
LDAP(Lightweight Directory Access Protocol)是一个严格遵循RFC 4511标准的目录访问协议,其删除操作(Delete Request)在协议层就定义为单DN、单对象、单事务——即每个DELETE请求仅能携带一个目标专有名称(DN),服务器不提供类似SQL中DELETE FROM ... WHERE IN (...)的批量语法。

因此,在PHP中处理多DN删除的唯一标准方式是显式循环:
⚠️ 关键注意事项:
总结而言,“批量删除”在LDAP中是语义伪命题——真正的优化方向不在减少函数调用次数,而在于提升单次操作的健壮性、可观测性与错误恢复能力。理解并接受协议边界,是构建可靠LDAP集成方案的第一步。