Heap Spraying: The IE createTextRange() exploit
I try to create a small HTML file to test this vulnerability.
.....
x = document.createElement("input");
x.type = "image";
y = x.createTextRange();
.....
I attach IE with WinDbg and browse this page. This is the result:
data:image/s3,"s3://crabby-images/2c870/2c870243eff4a4bc0e01fc836af31efd180f33d8" alt=""
IE crashs because of access violation - eip point to the address 0x3c0474c2. I have tested many times and IE still crashs at 0x3c0474c2 eventhough I open others application at the same time. I think this is the deterministic behavior of this vulnerability - may be useful for exploitation.
I begin to exploit the vulnerability by modify SkyLined's code and integrate it into my code. First of all, I wanna to know where is my injected heap. I inject 10 chunk of heap fill with nop + shellcode into the memory. After IE crash, I examine all heaps and I found this:
- 1 injected heap is in address range 0x01xxxxxx
- 2 injected heaps are in address range 0x02xxxxxx
- 7 injected heaps are in address range 0x06xxxxxx
- 1 injected heap is is address range 0x07xxxxxx
- first 4 bytes in each heap is the offset to last 4 bytes in heap
- all of injected heaps are in "Virtual Block"
- most of injected heap is in 0x06xxxxxx and 0x07xxxxxx address range
- the exploit takes more time to execute than the first time
- most of injected heap is in 0x0axxxxxx and 0x0bxxxxxx address range
- the exploit takes more time to execute than the second time
data:image/s3,"s3://crabby-images/7d708/7d708306ee8d994f7fbc5bf1315b8db6c8f434f5" alt=""
I try o increase number of chunk until 1700 chunks, there is something different from the past:
data:image/s3,"s3://crabby-images/db61c/db61c19502d77a841fb2f628618f218a08d13634" alt=""
data:image/s3,"s3://crabby-images/1dd34/1dd3427d179dfa573fd88e693bd802437d6c5c01" alt=""
Wow, our exploit was written in few hours. I have tried serveral times to ensure that the number 1700 is ok. Changing payload from "cc" instruction to "port binding" shellcode or "reverse connect" shellcode is also ok.
P.S. - Tested on Windows XP Professional Service Pack 2 and Internet Explorer 6.0