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 / 问题 / 45576
Accepted
Adam Brand
Adam Brand
Asked: 2009-07-26 11:23:02 +0800 CST2009-07-26 11:23:02 +0800 CST 2009-07-26 11:23:02 +0800 CST

为在 Active Directory 中创建新用户设置默认 UPN 后缀

  • 772

有没有办法设置默认 UPN 后缀来创建 Active Directory 的新用户?

例如,如果我将 corp.mydomain.com 作为我的 AD 域,并且我在 Domains and Trusts 下添加了一个备用 UPN 后缀,即 mydomain.com,那么在创建新域时有没有办法让该域成为默认域用户?

我知道我可以创建一个模板用户,然后当我复制它时,它将具有正确的默认后缀,但只是好奇是否有隐藏设置可以控制它。

active-directory
  • 5 5 个回答
  • 60755 Views

5 个回答

  • Voted
  1. MDMarra
    2013-10-15T17:01:45+08:002013-10-15T17:01:45+08:00

    据我所知,这是无法做到的(4年后埃文的回答仍然正确)。

    也就是说,我编写了一个脚本,每隔几个小时在任务调度程序中运行一个以上的客户端。它搜索特定的后缀(大多数情况下的默认后缀)并将其切换到另一个。脚本在我的博客上,但我也会在这里发布:)

    Import-Module ActiveDirectory
    
    
    Get-ADUser -Filter {UserPrincipalName -like "*@ad.example.com"} -SearchBase "OU=SomeUserOu,DC=ad,DC=example,DC=com" |
    ForEach-Object {
        $UPN = $_.UserPrincipalName.Replace("ad.example.com","example.com")
        Set-ADUser $_ -UserPrincipalName $UPN
    }
    

    在这种情况下,使用ad.example.comUPN 后缀创建的用户将使用后缀进行更新example.com。

    • 12
  2. Best Answer
    Evan Anderson
    2009-07-26T18:51:36+08:002009-07-26T18:51:36+08:00

    我知道没有记录的机制可以更改 Active Directory 用户和计算机选择的默认 UPN 后缀。我相信该工具是硬连线的,它采用在您的林中“CN=Partitions,CN=Configuration, ...”中指定的域的“crossRef”对象上定义的“canonicalName”属性的第一部分。

    AD 用户和计算机恰好天生就可以做到这一点。如果您使用其他方式(例如“NET USER ... /add”)创建用户帐户,则不会将任何 userPrincipalName 属性分配给该帐户。默认的 UPN 后缀实际上只是 AD 用户和计算机中的默认值,而不是目录服务本身的默认值。

    如果您遇到包含脚本的 Microsoft 知识库文章,该文章向您展示了如何以编程方式获取默认 UPN 后缀 ( http://support.microsoft.com/default.aspx?scid=kb;en-us;Q269441 ),请注意,该脚本中有几个语法错误(第 17 和 32 行格式错误,第 32 行的 srrNamingContext 应该是 strNamingContext)。我将在本文末尾包含一个经过小幅改进的固定版本(它向您显示了可能定义了其他 UPN 后缀的各个 OU 的名称)。

    我很想得到比我更“知情”的人的纠正,但我没有看到任何让 AD 用户和计算机采取不同行动的方法。

    ' --- Get the naming contexts ----
    Set RootDSE = GetObject("LDAP://RootDSE")
    strNamingContext = RootDSE.Get("defaultNamingContext")
    strConfigContext = RootDSE.Get("configurationNamingContext")
    
    ' -- Get the current domain name --
    Set oDomain = GetObject("LDAP://" + strNamingContext)
    strDomainName = oDomain.Get("name")
    
    Set oPartition = GetObject("LDAP://CN=Partitions," & strConfigContext)
    
    '-- Get the DNS name of the domain --
    oDomain.GetInfoEx Array("canonicalName"), 0
    strCanonical = oDomain.Get("canonicalName")
    strDNSName = Left(strCanonical, Len(strCanonical) - 1) 'clip off "/"
    
    '-- Display the default UPN suffix
    wscript.echo strDNSName
    
    '-- Get the defined upnSuffixes --
    suffixes = oPartition.GetEx("UPNSuffixes")
    For Each upnSuffix In suffixes
      wscript.echo upnSuffix
    Next
    Set RootDSE = Nothing
    Set oDomain =Nothing
    Set oPartition = Nothing
    
    ' -- Get the upnsuffixes defined on organizational units --
    Set ADOconn = CreateObject("ADODB.Connection")
    Set ADOcom = CreateObject("ADODB.Command")
    
    ADOconn.Provider = "ADsDSOObject"
    bstrADOQueryString = "<LDAP://" + strNamingContext + ">;(objectcategory=organizationalUnit);upnsuffixes,ADsPath;subtree"
    wscript.echo bstrADOQueryString 
    ADOconn.Open
    ADOcom.ActiveConnection = ADOconn
    
    ADOcom.CommandText = bstrADOQueryString
    ADOcom.Properties("Page Size") = 99
    
    Set objRS = ADOcom.Execute
    
    While Not objRS.EOF
       If Not IsNull(objRS.Fields("upnSuffixes")) Then
        upnsuffixes = objRS.Fields("upnSuffixes")
        For Each upnsuffix In upnsuffixes
            wscript.echo objRS.Fields("adsPath") & " - Suffix: " & upnsuffix
        Next
       End If
    
       objRS.MoveNext
    Wend
    
    Set objRS = Nothing
    Set ADOcom = Nothing
    Set ADOconn = Nothing
    
    • 9
  3. Justin Robbins
    2016-01-07T06:14:35+08:002016-01-07T06:14:35+08:00

    您可以设置允许的 UPN 后缀,进入 ADSIEDIT.MSC,插入 OU 结构,右键单击 OU(在默认配置中),然后编辑 OU 属性。要编辑的 OU 属性是 UPNSuffixes。但是,这不会影响分配给在该 OU 中创建的用户的默认 UPN。将所需的 UPN 后缀添加到此列表中。接下来,创建要复制的模板用户。右键单击 OU,创建一个新用户以用作模板,分配正确的 UPN 后缀,然后在创建后右键单击该用户并禁用帐户。要创建新用户,请右键单击模板用户并复制 .. 填写所选字段,然后将使用正确的 UPN 创建新用户。为不同的 UPNS 创建多个模板用户。或者,如果有疑问,请切换到 powershell。

    • 0
  4. Herb Huddleston
    2015-08-19T08:51:39+08:002015-08-19T08:51:39+08:00

    实际上,您可以在 Powershell 的 Active Directory 模块中运行:Set-ADOrganizationalUnit "OU=XXX,DC=Domain,DC=com" -Add @{upnsuffixes="@UPNSuffix.com"。

    或者您可以使用带有 -Filter 开关的“Get-adorganizationalUnit”并将其通过管道传送到“Set-ADOrganizationalUnit -Add @{upnsuffixes="@UPNSuffix.com"'

    找了好久才发现这个,希望对大家有帮助。

    • -3
  5. Maximus Minimus
    2009-07-27T04:30:38+08:002009-07-27T04:30:38+08:00

    这篇 technet 文章介绍了如何在您的域中添加或删除 UPN 后缀:

    http://technet.microsoft.com/en-us/library/cc756018(WS.10).aspx

    这里也有讨论:

    http://technet.microsoft.com/en-us/library/cc739093(WS.10).aspx

    我不能亲自担保,因为我从来没有这样做过,但有一件事确实浮现在脑海中。如果您要执行此操作,您需要记住,虽然 AD 可以正常工作,但您拥有的任何 3rd 方软件可能并非如此,它可能假定 UPN 后缀始终是标准的. 换句话说,在做出改变之前仔细考虑后果。

    • -4

相关问题

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

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

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

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

  • 通过 VPN 更改 Active Directory 密码

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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