ldap - 使用 ldapsearch 进行 G Suite LDAP 搜索
问题描述
我已经在 G Suite 中配置了一个 ldap 应用程序,并且我已经下载了证书和密钥。我正在尝试通过 ldapsearch 查询它:
LDAPTLS_CERT="Google_cert.crt" \
LDAPTLS_KEY="Google_cert.key" \
ldapsearch -H ldaps://ldap.google.com:636 -b dc=XXXXX,dc=XXX -x '(mail=first.last@XXXXX.XXX)'
我得到的回应是这样的:
# extended LDIF
#
# LDAPv3
# base <dc=XXXXX,dc=XXX> with scope subtree
# filter: (mail=first.last@XXXXX.XXX)
# requesting: ALL
#
# search result
search: 2
result: 0 Success
# numResponses: 1
我不确定如何解释响应。它是否执行了搜索但什么也没找到?search
,result
和是什么numResponses
意思?
我期待更多信息,因为我正在寻找自己,所以我知道我在那里。我的查询有问题吗?
编辑
根据评论,我将查询更改为*
:
LDAPTLS_CERT="Google_cert.crt" \
LDAPTLS_KEY="Google_cert.key" \
ldapsearch -H ldaps://ldap.google.com:636 -b dc=XXXXX,dc=XXX -x '*'
得到了这个:
# extended LDIF
#
# LDAPv3
# base <dc=XXXXX,dc=XXX> with scope subtree
# filter: (objectclass=*)
# requesting: *
#
# XXXXX.XXX
dn: dc=XXXXX,dc=XXX
objectClass: top
objectClass: domain
objectClass: dcObject
dc: XXXXX
# Groups, XXXXX.XXX
dn: ou=Groups,dc=XXXXX,dc=XXX
objectClass: top
objectClass: organizationalUnit
ou: Groups
# search result
search: 2
result: 0 Success
# numResponses: 3
# numEntries: 2
这是否意味着唯一的下一级容器是Groups
,下一个我需要在那个ou中搜索?
解决方案
I'm on a Mac, and ldapsearch
on Mac is different. Instead of using LDAPTLS_CERT & LDAPTLS_KEY, I had to convert the certificate and key files to one PKCS12 formatted file and import them into my MacBook's keychain, then use the LDAPTLS_IDENTITY environment variable with the ldapsearch command. This page Connect LDAP clients to the Secure LDAP service has specific instructions for using ldapsearch on MacOS.
After that, this is the command that found my user:
LDAPTLS_IDENTITY="LDAP Client" ldapsearch -H ldaps://ldap.google.com:636 -b dc=XXXXX,dc=XXX '(uid=first.last)'
Hope this saves somebody else some time.
推荐阅读
- database - 数据库上的 CI/CD 实现
- node.js - NodeJS - 如何使用 node-opcua-pki 生成证书和私钥
- django - 重定向,无法离开登录页面
- powershell - Powershell Umlaute 检查始终显示错误
- deep-learning - 在目标检测中训练出误报
- python - 返回包含除“名称”之外的所有列的数据框
- ios - 如何在应用内购买处于“已批准”状态时提交审核
- node.js - 谷歌云 SQL 登录因繁琐而失败
- amazon - 使用 curl 连接到 Amazon Selling Partner API
- reactjs - nextjs 中的 getStaticProps