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
    • 最新
    • 标签
主页 / unix / 问题 / 411834
Accepted
k.Cyborg
k.Cyborg
Asked: 2017-12-20 07:18:48 +0800 CST2017-12-20 07:18:48 +0800 CST 2017-12-20 07:18:48 +0800 CST

如何在 Samba Active Directory 中导出完整的用户列表?

  • 772

我有一个 Active Directory 运行Samba 4.6.3在一个服务器上Debian Jessie。在 Windows 7 PC(AD 客户端)上,我安装了RSAT,并从那里使用管理员帐户管理服务器,但现在我需要以可读格式导出完整的用户列表,最好是.csv

使用RSAT(来自 Windows 中的客户端)到目前为止,我只成功导出了OU(组织单位)内的所有对象,一次OU一个,OU用户容器或 PC 容器,也就是说,我可以做什么我想通过为每个OU用户容器重复该过程来(导出完整的用户列表),但我有很多OU用户容器。

问题:有没有什么方法可以快速导出完整的用户列表,包括姓名和姓氏,OU并且无需重复工作?

PD:答案不必局限于带有 RSAT 的 Windows 中的客户端,也可以在 Samba 服务器中

users samba
  • 1 1 个回答
  • 4787 Views

1 个回答

  • Voted
  1. Best Answer
    John
    2017-12-20T11:09:27+08:002017-12-20T11:09:27+08:00

    Bash 解决方案.. 部分...

    从提取 AD 内容开始:

    ldapsearch -s -h <ADHOST> -P <ADPORT> -D <USERDN WITH RIGHTS TO READ AD> -W -E pr-1000/noprompt -b <BASEDN FOR SEARCH> > ad_extract_tmp.ldif
    

    “-W”强制交互式提示输入用户密码。您不希望它出现在命令历史记录中。如果您将其组合到一个脚本中,那么您可以使用“-w”并保护密码访问。

    现在内容已被提取到文本文件中,我们可以使用文本处理将其转换为 CSV 或我们想要的任何其他格式。

    ldif 文件被包装,所以第一步是解开它

    awk ' BEGIN (RS="\n\n"; FS="\n "} {for (i=1,i<=NF;i++) printf $i; printf "\n\n"}' ad_extract_tmp.ldif > ad_extract_tmp.ldif.unwrapped
    

    在这里,我们将记录重新定义为包含一个具有两个行尾的文本块和一个包含一个只有一个行尾和一个空格的文本块的字段。接下来,我们将每一行作为一个字段处理,将 ldif 包装的点赞(“\n”)连接到一个字段中。现在我们有了一个展开的 ldif,最后一步是将 ldif 转换为 csv。

    awk ' Begin {
                 record = "false";
                 print "\x22uid\x22,\x22dn\x22";
      }
      { if ( record = "true") {
    
           if ( $0 ~ /~sAMAccountName./) {
             uid = $0;
             sub (/^.*: /,"",uid);
            }
    
           if ( $0 ~ /^\s*$/) {
               print "\x22" uid "\x22,\x22" dn "\x22";
               dn = "";  record = "false";
             }
          }
      }
      {
        if ($0 ~ /^dn:./) {
           record = "true";
           dn = $0;
         }
      }' ad_extract_tmp.ldif.unwrapped > ad_extract.csv
    

    这是一个大大简化的 awk 转换脚本,它将解开的 ldif 转换为 csv。

    可以将 dn 提取给用户 ou 并获取所需的其他字段。只需扩展最终的 awk 脚本。

    • 1

相关问题

  • 挂载 samba 共享时出错:CIFS VFS:未指定用户名

  • 我可以在不删除主目录的情况下对用户进行 userdel 吗?

  • 删除用户时会删除用户的主要组吗?

  • 即使我在文件上设置了全局读取权限,也得到“权限被拒绝”

  • Iptables 规则允许 appVM 通过配置为仅通过 QubesOS 中的 VPN 的 proxyVM

Sidebar

Stats

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

    JSON数组使用jq来bash变量

    • 4 个回答
  • Marko Smith

    日期可以为 GMT 时区格式化当前时间吗?[复制]

    • 2 个回答
  • Marko Smith

    bash + 通过 bash 脚本从文件中读取变量和值

    • 4 个回答
  • Marko Smith

    如何复制目录并在同一命令中重命名它?

    • 4 个回答
  • Marko Smith

    ssh 连接。X11 连接因身份验证错误而被拒绝

    • 3 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Marko Smith

    systemctl 命令在 RHEL 6 中不起作用

    • 3 个回答
  • Marko Smith

    rsync 端口 22 和 873 使用

    • 2 个回答
  • Marko Smith

    以 100% 的利用率捕捉 /dev/loop -- 没有可用空间

    • 1 个回答
  • Marko Smith

    jq 打印子对象中所有的键和值

    • 2 个回答
  • Martin Hope
    EHerman JSON数组使用jq来bash变量 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux 日期可以为 GMT 时区格式化当前时间吗?[复制] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC 如何复制目录并在同一命令中重命名它? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve “root”用户的文件权限如何工作? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey 如何下载软件包而不是使用 apt-get 命令安装它? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao 为什么目录 /home、/usr、/var 等都具有相同的 inode 编号 (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg —list-keys 命令在将私钥导入全新安装后输出 uid [未知] 2017-11-26 18:26:02 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve