专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

ahaen/azuread-ldap-wrapper Docker 镜像 - 轩辕镜像

azuread-ldap-wrapper
ahaen/azuread-ldap-wrapper
基于Node.js的LDAP服务器,允许通过LDAP协议访问Azure Active Directory的用户和组,使用Microsoft Graph API进行用户认证,适用于缺乏AzureAD支持的旧应用或无需本地AD控制器的场景。
9 收藏0 次下载
💣 CI/CD 卡在拉镜像?问题不在代码,在镜像源
中文简介版本下载
💣 CI/CD 卡在拉镜像?问题不在代码,在镜像源

AzureAD-LDAP-wrapper:Azure Active Directory的LDAP包装器 ![GitHub release (latest by date)]([***]

AzureAD-LDAP-wrapper是一个基于Node.js的LDAP服务器(构建于ldapjs之上),允许通过LDAP协议访问Azure Active Directory中的用户和组。用户认证在每次登录尝试时通过Microsoft Graph API执行。这使得其他应用程序能够连接到LDAP服务器并使用AzureAD登录凭据,使其成为缺乏AzureAD支持的旧应用程序或不需要管理本地AD控制器场景的可能解决方案。

背景

AzureAD-LDAP-wrapper启动一个LDAP服务器,并从AAD Graph API获取用户和组信息。这些信息会被缓存并在本地合并。

当LDAP客户端尝试使用用户凭据进行绑定(bind)时,AzureAD-LDAP-wrapper通过与AAD Graph API通信来检查这些凭据。如果凭据有效,AAD Graph API会向AzureAD-LDAP-wrapper发送成功响应,然后AzureAD-LDAP-wrapper向用户的LDAP客户端发送成功绑定消息。此外,AzureAD-LDAP-wrapper会将用户的密码哈希保存在sambaNTPassword属性中,并将sambaPwdLastSet属性设置为“当前时间”。这允许用户从Windows电脑访问Samba共享(如NAS上的共享)。

AzureAD-LDAP-wrapper每30分钟定期从AAD Graph API获取用户和组信息,合并结果并在本地缓存。此过程会保留uid、gid、sambaNTPassword和sambaPwdLastSet等属性。

快速开始

要求

使用AzureAD-LDAP-wrapper需要:

  • 一个Azure Active Directory (AD)租户,至少包含一个已注册用户。

  • 在租户中注册的Azure AD应用程序,具有以下权限:

    • 对于“应用程序”类型,授予User.Read.All和Group.Read.All权限。
    • 对于“委派”类型,授予User.Read权限。

    您可以按照安装指南中的说明设置应用程序。

运行AzureAD-LDAP-wrapper需要准备租户ID(Tenant ID)、应用ID(Application ID)和应用密钥(Application Secret)。这些值用于认证和授权应用程序访问Azure AD资源,可在Azure门户中找到。

创建Azure AD应用程序后,可以在本地计算机、服务器甚至Synology NAS上运行LDAP包装器。根据设置,您需要:

  • Node.js 17或更高版本,可从Node.js官方网站下载。

或

  • Docker,可从Docker官方网站下载。

注意,包装器的某些功能可能需要额外的配置或依赖项,例如用于网络存储访问的NAS。

运行LDAP包装器

有多种运行LDAP包装器的方式。有关更多信息,请查阅文档以开始使用。

在Synology NAS上运行LDAP包装器的一种方法如下:

  1. 从Synology套件中心安装Docker。 !套件中心

  2. 在Docker中,转到“注册表”下载最新的容器镜像。 !下载最新镜像

  3. 在Docker中,转到“映像”启动新容器。使用“bridge”作为网络。 !启动映像 使用“bridge”作为网络。

  4. 为容器命名并启用自动重启。 !名称设置

  5. 在“高级设置”中配置环境变量。确保仔细检查Azure相关值,并至少定义一个绑定用户(binduser)。绑定用户(如root等超级用户)不需要存在于AzureAD中。将example.com替换为您的域名。以下是最小所需配置示例:

    bash
    TZ: "Europe/Zurich" # 可选
    AZURE_TENANTID: "0def2345-ff01-56789-1234-ab9d6dda1e1e"
    AZURE_APP_ID: "abc***-ab01-0000-1111-a1e1eab9d6dd"
    AZURE_APP_SECRET: "iamasecret~yep-reallyreallysecret"
    LDAP_DOMAIN: "example.com"
    LDAP_BASEDN: "dc=example,dc=com"
    LDAP_BINDUSER: "ldapsearch|*secretldapsearch123*||root|*secretroot*"
    LDAP_DEBUG: "false" # 设置为true以获取更多日志
    GRAPH_IGNORE_MFA_ERRORS: "false" # 设置为true以绕过MFA
    DSM7: "true" # 如果运行DSM 6或更低版本,设置为false
    

    !环境变量 所有环境变量的完整列表可在配置设置页面找到。

  6. 将本地端口389映射到容器端口***。如果收到“本地端口389与其他服务冲突”的错误,请确保未安装Synology Directory Service和Synology LDAP Server,它们也使用此端口。 !端口设置

  7. 在卷设置中,将本地文件夹(如docker/ldap)挂载到路径/app/.cache。如果跳过此步骤,数据将不会永久存储。 !文件夹挂载

  8. 点击“完成”启动容器。 !完成设置

使用方法

要允许用户使用Azure凭据登录Synology NAS,需要将NAS连接到AzureAD-LDAP-wrapper。步骤如下:

  1. 进入控制面板 > 域/LDAP,点击“加入”。 !LDAP加入

  2. 输入NAS的IP地址(如127.0.0.1)作为服务器地址。 !服务器地址

  3. 输入先前定义的超级用户凭据(环境变量LDAP_BINDUSER)作为绑定DN(Bind DN)。如果用户未找到,尝试使用“uid=root”或完整名称“uid=root,cn=users,dc=domain,dc=tld”而非仅“root”。在Base DN中选择您的域。 !输入LDAP信息

  4. 如果看到关于本地组与同步组名称相同的警告,可以忽略并在“详情”中跳过警告。 !跳过警告

  5. NAS现在应已成功连接到Azure AD LDAP包装器。 !NAS已连接

  6. 检查“LDAP用户”和“LDAP组”选项卡,确保所有条目已完全同步。为同步的用户和组分配所需权限。现在可以使用Azure AD凭据登录。 !检查用户

  7. 注意,在通过网络或Samba访问共享文件夹或文件之前,每个用户必须先登录DSM Web GUI或其他直接连接到LDAP服务器的工具。密码更改后也需要执行此步骤,因为Samba的密码哈希仅在成功登录后设置。

设置

配置LDAP包装器可使用环境变量(因为其设计用于Docker)。所有可用变量的完整列表可在文档的配置设置页面找到。

故障排除

如果遇到任何问题,首先检查Docker日志。许多错误会记录在日志中,有助于识别问题根源。此外,文档的故障排除页面提供了调试常见问题(包括Samba相关问题)的进一步指导。如果仍无法解决,请提交issue并附上相关日志文件以帮助诊断。

安全性

请注意,AzureAD-LDAP-wrapper涉及敏感用户信息的传输,因此确保安全使用至关重要。使用此包装器时存在一些潜在安全风险。有关这些风险及缓解措施的更多信息,请阅读文档的安全页面。

如果发现任何安全漏洞,请参考SECURITY.md中的说明进行报告。

贡献

欢迎对AzureAD-LDAP-wrapper做出贡献!如有任何建议、错误报告或拉取请求,请随时在项目的GitHub仓库上提交issue或拉取请求。

支持此项目

如果您发现此项目有帮助或为您节省了时间和精力,请考虑给予星标(star)和/或***。

您的支持有助于我维护和改进此项目。谢谢!

许可证

AzureAD-LDAP-wrapper采用MIT许可证授权。

查看更多 azuread-ldap-wrapper 相关镜像 →
lldap/lldap logo
lldap/lldap
轻量级LDAP实现,用于身份认证,简化LDAP使用流程。
101M+ pulls
上次更新:未知
bitnami/openldap logo
bitnami/openldap
Bitnami Secure Image for openldap 是由 Bitnami 提供的一款针对 OpenLDAP(轻量级目录访问协议的开源实现,广泛用于用户认证、授权及目录服务管理)的预配置安全镜像,该镜像经过安全加固,集成了优化的配置、必要的依赖管理及最新安全补丁,旨在帮助用户快速、安全地部署 OpenLDAP 服务,适用于企业级环境,确保目录服务的稳定性与数据安全性,简化部署流程并降低运维复杂度。
15110M+ pulls
上次更新:未知
demisto/ldap logo
demisto/ldap
暂无描述
100K+ pulls
上次更新:未知
pingidentity/ldap-sdk-tools logo
pingidentity/ldap-sdk-tools
便携、易于运行且功能全面的LDAP工具Docker镜像
6100K+ pulls
上次更新:未知
linuxserver/ldap-auth logo
linuxserver/ldap-auth
linuxserver/ldap-auth是基于nginx-ldap-auth的Docker镜像,用于通过LDAP认证保护Nginx代理的资源,包含认证守护进程和生成认证Cookie的Web服务器,支持OpenLDAP和Microsoft Active Directory,提供定期更新、用户映射及安全增强功能。
885M+ pulls
上次更新:未知
phpldapadmin/phpldapadmin logo
phpldapadmin/phpldapadmin
phpLDAPadmin是一款面向系统管理员的基于Web的LDAP数据管理工具。
350K+ pulls
上次更新:未知

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

MacOS OrbStack

MacOS OrbStack 容器配置

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
ahaen/azuread-ldap-wrapper
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
咨询镜像拉取问题请 提交工单,官方技术交流群:1072982923
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
咨询镜像拉取问题请提交工单,官方技术交流群:
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.