AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 401514
Accepted
Zac
Zac
Asked: 2012-06-23 14:33:11 +0800 CST2012-06-23 14:33:11 +0800 CST 2012-06-23 14:33:11 +0800 CST

带 LDAP over SSL 的 ISAPI 过滤器只能以管理员身份工作

  • 772

我已经为 IIS 6.0 创建了一个 ISAPI 筛选器,它尝试使用 LDAP 针对 Active Directory 进行身份验证。当定期通过端口 389 进行身份验证时,过滤器工作正常,但是当我尝试使用 SSL 时,我总是在调用时遇到0x51 Server Down错误。ldap_connect()即使跳过连接调用并使用也会ldap_simple_bind_s()导致相同的错误。

奇怪的是,如果我将应用程序池身份更改为本地管理员帐户,则过滤器可以正常工作并且 LDAP over SSL 成功。我用下面相同的代码创建了一个 exe,并以管理员身份在服务器上运行它,它可以工作。为站点的应用程序池使用默认的 NETWORK SERVICE 身份似乎是问题所在。关于正在发生的事情有什么想法吗?我想使用默认身份,因为我不希望该网站具有更高的管理员权限。

服务器位于运行 AD 的 DC 所在的网络和域之外的 DMZ 中。我们的 DC 上也有适用于 AD 的有效证书。

代码:

// Initialize LDAP connection
LDAP * ldap = ldap_sslinit(servers, LDAP_SSL_PORT, 1);
ULONG version = LDAP_VERSION3;

if (ldap == NULL)
{
    strcpy(error_msg, ldap_err2string(LdapGetLastError()));
    valid_user = false;
}
else
{
    // Set LDAP options
    ldap_set_option(ldap, LDAP_OPT_PROTOCOL_VERSION, (void *) &version);
    ldap_set_option(ldap, LDAP_OPT_SSL, LDAP_OPT_ON);

    // Make the connection
    ldap_response = ldap_connect(ldap, NULL); // <-- Error occurs here!

    // Bind and continue...
}

更新:我创建了一个没有管理员权限的新用户,并以新用户身份运行测试 exe,但我遇到了同样的Server Down错误。我将用户添加到管理员组并得到了同样的错误。似乎在此特定服务器上使用 LDAP over SSL 身份验证的唯一用户是管理员。

带有 ISAPI 过滤器的 Web 服务器(以及我运行测试 exe 的位置)正在运行 Windows Server 2003。带有 AD 的 DC 正在运行 2008 R2。

另外值得一提的是,我们在同一台服务器上有一个 WordPress 站点,该站点使用 PHP (OpenLDAP) 通过 SSL 对 LDAP 进行身份验证,这没有问题。我有一个指定的 ldap.conf 文件,TLS_REQCERT never运行 PHP 代码的用户是 IUSR。

active-directory ssl isapi
  • 2 2 个回答
  • 682 Views

2 个回答

  • Voted
  1. Best Answer
    ixe013
    2012-06-23T17:56:18+08:002012-06-23T17:56:18+08:00

    确保失败的用户信任您的 ldap 服务器的证书颁发机构。

    为此,请以失败的用户身份登录(您可能必须为此授予临时权限,也许将其放在“远程桌面”组中)。在“受信任的根证书颁发机构”下启动certmgr.msc并查找您正在使用的证书颁发机构。

    将您看到的内容与管理员帐户中的内容进行比较。

    • 1
  2. Brennan
    2012-06-23T18:55:00+08:002012-06-23T18:55:00+08:00

    我相信您遇到了信任商店问题。

    请参阅http://www.microsoft.com/resources/documentation/windows/xp/all/proddocs/en-us/sag_cmuncertstor.mspx?mfr=true

    测试此方法的示例方法可能是区分打印证书存储内容的基于文本的输出。

    • 0

相关问题

  • 如果以域用户身份远程登录,PC 速度极慢

  • 如何在 Windows 2003 的 ou 级别应用策略

  • 允许用户更改其 Active Directory 密码的 Web 界面

  • MOSS 2007 无法使用 ActiveDirectoryMembershipProvider 配置表单身份验证

  • 通过 VPN 更改 Active Directory 密码

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve