• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            一個管道有讀端和寫端,當你把這個管道和一個進程搭接起來的時候,可以用這個管道當作輸入,也可以用這個管道當作輸出,如果是要向管道輸入,則數據輸入端是寫端,另一端是讀端,如果是由管道輸出,則由進程寫入管道,是寫端,另一端是讀端,也就是接收進程的輸出數據的一端,因此如果要重定向進程的輸入和輸出,則需要2根管道.
            以下代碼演示了創建CMD.EXE進程,并用2根管道重定向他的輸入輸出,并讀取CMD產生的結果數據.
            千萬不要忘記設置SECURITY_ATTRIBUTES里的bInheritHandle,比如創建管道的時候要把bInheritHandle設置為TRUE

            同樣不一定要用管道,比如文件,SOCKET等都可以重定向.
            如果是用SOCKET,根據網上的名詞,可以創建一個"零管道后門"程序.比如在服務器端上的后門程序監聽某個端口,一旦有連接請求,接受后創建SOCKET,就在這個時候開啟CMD.EXE,并重定向輸入輸出到服務器上的這個SOCKET,這樣便為遠程的這個連接請求開了一個服務器上的后門,從而遠程連接可以執行服務器并返回結果.
            演示代碼如下:
            //
            // File: Main.cpp
            // Purpose: Creates a process( cmd.exe for example ), and redirect its standard input
            //   by using creating a pipe, then writes some bytes as commands to pipe.
            //
            #define WIN32_LEAN_AND_MEAN
            #include <windows.h>

            #include <stdio.h>
            #include <stdlib.h>

            // Error report
            void Error( const char *szErrMsg );

            int main( int argc, char **argv )
            {
             // Create pipe
             BOOL bRet;
             HANDLE hPipeRead, hPipeWrite;
             HANDLE hPipeReadII, hPipeWriteII;
             SECURITY_ATTRIBUTES sa;
             sa.nLength = sizeof( SECURITY_ATTRIBUTES );
             sa.bInheritHandle = TRUE;
             sa.lpSecurityDescriptor = NULL;
             bRet = ::CreatePipe( &hPipeRead, &hPipeWrite, &sa, 512 );
             bRet &= ::CreatePipe( &hPipeReadII, &hPipeWriteII, &sa, 512 );
             if ( !bRet )
             {
              Error( "Can't create pipe!" );
              return -1;
             }
             // Spawn a process
             STARTUPINFO StartInfo;
             PROCESS_INFORMATION ProcessInfo;
            // memset( &StartInfo, 0, sizeof(StartInfo) );
            // memset( &ProcessInfo, 0, sizeof(ProcessInfo) );
             ::GetStartupInfo( &StartInfo );
             StartInfo.cb = sizeof(StartInfo);
             StartInfo.dwFlags = STARTF_USESHOWWINDOW | STARTF_USESTDHANDLES;
             StartInfo.wShowWindow = SW_HIDE;
             StartInfo.hStdInput = hPipeRead;
             StartInfo.hStdOutput = hPipeWriteII; //::GetStdHandle( STD_OUTPUT_HANDLE );
             StartInfo.hStdError = hPipeWriteII; //::GetStdHandle( STD_OUTPUT_HANDLE );
             bRet = ::CreateProcess( TEXT("c:\\windows\\system32\\cmd.exe"), NULL, NULL, NULL, TRUE, 0, NULL, NULL, &StartInfo, &ProcessInfo );
             ::Sleep(1000);
             printf("wake up...\n");
             if ( !bRet )
             {
              Error( "Can't create process!" );
              return -1;
             }
             // Write commands to pipe
             char *szCmd = "netstat\r\n";
             DWORD dwDummy;
             ::WriteFile( hPipeWrite, szCmd, 10, &dwDummy, NULL );
             ::Sleep(2000);
             printf("had written...\n");
             // Read from pipe
             char szBuf[1024];
             memset(szBuf, 0, sizeof(szBuf));
             ::ReadFile( hPipeReadII, szBuf, sizeof(szBuf), &dwDummy, NULL );
             // Don't leave till the spawned process goes end
            // ::Sleep(2000);
             printf("had read...\n");
            // ::WaitForSingleObject( ProcessInfo.hProcess, INFINITE );
             printf("%s\n", szBuf);

             return 0;
            }

            void Error( const char *szErrMsg )
            {
             printf( "Error: %s\n", szErrMsg );
            }


            在WinXP SP2 + VS 2005 Express Edition上編譯并運行通過
            這個版本的VS需要下載并設置Platform SDK,并另外找一個MSVCRT80D.DLL如果是DEBUG版本的DLL,并設置
            包含和鏈接目錄和鏈接器命令行(user32,kernel32,libcmt)
            posted on 2010-05-25 23:07 Reno 閱讀(605) 評論(0)  編輯 收藏 引用 所屬分類: Windows系統編程

            統計

            久久久WWW成人免费精品| 波多野结衣久久一区二区 | 女人高潮久久久叫人喷水| 中文字幕久久精品| 久久精品黄AA片一区二区三区| 久久亚洲精品成人AV| 国产免费久久精品丫丫| 国产欧美久久久精品影院| 狠狠色婷婷综合天天久久丁香 | 精品久久久久中文字幕一区| 亚洲乱码日产精品a级毛片久久| 亚洲AV日韩AV永久无码久久| 一级做a爰片久久毛片16| 国产香蕉久久精品综合网| 国产亚洲婷婷香蕉久久精品| 久久婷婷五月综合国产尤物app | 亚洲日韩欧美一区久久久久我| 国产午夜福利精品久久2021| 久久精品桃花综合| 国产精品无码久久综合网| 久久亚洲春色中文字幕久久久| 国产精品成人99久久久久 | 久久久久这里只有精品| 丰满少妇高潮惨叫久久久| 99久久综合国产精品免费| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 亚洲国产天堂久久综合网站| 狠狠色婷婷久久一区二区| 青春久久| 久久亚洲国产精品123区| 91精品国产91久久久久久| 久久精品国产亚洲AV无码偷窥| 色妞色综合久久夜夜| 精品久久久久久无码不卡| 久久亚洲国产精品五月天婷| 久久久久久国产精品无码下载| 久久精品国产亚洲网站| 久久青草国产手机看片福利盒子| 人妻无码αv中文字幕久久琪琪布| 日日狠狠久久偷偷色综合96蜜桃| 91精品观看91久久久久久|