data:image/s3,"s3://crabby-images/db68a/db68a469c52560f68034ae4b27021d82cb2580c4" alt="Random PowerShell cmdlets."
Random Code Generation in PowerShell-Based Malware “sLoad”
Every once in a while, malware will surprise me with a new technique, or a new method of implementing an older technique. It’s kind of like malware analysis Christmas. Unpacking a gift (the malware) and getting a new toy. Nevermind.
Anyway, I was looking into a new “sLoad” sample the other day. “sLoad” is a Powershell-based Trojan downloader that implements a number of interesting techniques, but one special technique that I wanted to highlight with this post. I will not be covering the entire sLoad infection chain in detail here. If you want more information on sLoad, Microsoft put together a great analysis:
https://www.microsoft.com/security/blog/2020/01/21/sload-launches-version-2-0-starslord/
Buried in this sLoad PowerShell script, there is a call to a function “Get-Command -type Cmdlet”, as well as a call to “Get-Random -count 18”. “Get-Command” is typically called by system admins or developers who wish to get a list of various PowerShell functions that can be used for a certain task. In this case, the sLoad code is essentially generating a random subset (18, to be exact) of PowerShell cmdlets, and storing the resultant list in a variable ($r, in this case).
data:image/s3,"s3://crabby-images/82427/8242756fb31fdbea8a2e5619f325dfd421c70ced" alt=""
We can see the $r variable populated with these 18 random PowerShell cmdlets:
data:image/s3,"s3://crabby-images/3d068/3d068f809c16d32da7cebc35db0ce0f07bf1ff61" alt="Random PowerShell cmdlets."
To prove to you (and to me) that I’m not crazy, I ran this code again for your viewing pleasure and received the following new list of 18 random cmdlets:
data:image/s3,"s3://crabby-images/f361f/f361f2f4c17af1c3fca3f9a5840c81dfb0a16296" alt="More random PowerShell cmdlets."
Further on in the code, this list of random cmdlets is then separated with try/catch statements, and other code:
data:image/s3,"s3://crabby-images/89b7e/89b7e3b993a1b54e66a1e65eb01a8191a621edac" alt="sLoad random code generation."
Finally, this end result is written to another PowerShell file and dropped to disk. The resulting script looks like the following:
data:image/s3,"s3://crabby-images/4c226/4c22687df112f7cb9fa13c51453abcf6cceefb56" alt="sLoad final dropped script with random cmdlets."
We can see our random cmdlets that don’t actually serve a purpose here, and they will fail to run. Their main purpose is to obfuscate the code a bit, confusing the analyst, and burying the actual malicious functions in a small sea of garbage. In addition, these extra cmdlets likely confuse some endpoint defenses as well (such as EDR and AV).
The interesting thing is that I have not seen any additional information on the Internet for this technique, including in the Microsoft blog post.
As previously mentioned, I won’t go into detail on the malicous functiioanlity, but to quickly summarize, this script is loading a previously-dropped encrypted file (system.ini), which is then decrypted. I may write a follow up post on this decryption functionality as this is interesting as well.
Anyway, I simply wanted to highlight the random code-generation capabilities of this interesting sLoad variant. Please contact me (@d4rksystem) if you see something incorrect in this post or have additional comments!
As always, thanks for reading! If you enjoyed this post, follow me on Twitter (@d4rksystem).