1

私はこの問題に関する答えを数日間探していました。皆さんが私を助けてくれることを願っています。(私はいくつかの解決策を検索して見つけましたが、それぞれに独自の問題があります...)。

これが重要です。私は仕事で自動化を書いています。これは、同僚が書いたコードの外部「.exe」ファイルを起動する役割を果たします。彼らが書いたプログラムは顧客に提供されるので、私は彼らのコードに変更を加えることは許可されていません。これらのプログラムは、起動されると、特定のキーストロークを待機し、正当なキーストロークが受信されるとメッセージを出力します。

私の目標はこれです:外部プログラムを実行するプログラムを作成し、それにキーストロークを送信し、それらのstdoutから出力を受信します。これまでのところ、(ShellExecuteを使用して)自分のプログラムからプログラムを実行し、(SendMessageを使用して)ある種のキーボードリスナーを他のプログラムにシミュレートすることができました。私はそれが機能することを見ることができます-私はテストされたプログラムのコンソールで出力を見ることができます。

テストしたプログラムのシェルに出力されたメッセージをリアルタイムでフェッチしようとしています(プログラムの終了時に大量のデータを取得するだけです)。これにより、発生時に分析できるようになります。

私が試したもの:

  • テキストファイルへのインライン出力リダイレクトを使用した外部バッチファイルの書き込み。
  • freopenを使用します。
  • 「ShellExecute」の実行中に出力をリダイレクトします。
4

1 に答える 1

0

stdin、stdout、および stderr のハンドルを使用します。そのハンドルを取得するには、CreateProcess 関数でプロセスを作成します。サンプルコード - あなたのケースでは不完全ですが、それを行う方法の良い例:

#include <windows.h>
#include <stdio.h>
#include <tchar.h>

    /*for test.exe
#include <iostream>
#include <string> */

void _tmain( int argc, TCHAR *argv[] )
{
    /*for test.exe
    std::cout << "test output" << std::endl;
    for (;;)
    {
        std::string line;
        std::getline(std::cin, line);
        std::cout << "line: " << line << std::endl;
    }
    return;*/
    STARTUPINFO si;
    PROCESS_INFORMATION pi;

    ZeroMemory( &si, sizeof(si) );
    si.cb = sizeof(si);
    ZeroMemory( &pi, sizeof(pi) );

    // Start the child process. 
    if( !CreateProcess( NULL,   // No module name (use command line)
        "test.exe",        // Command line
        NULL,           // Process handle not inheritable
        NULL,           // Thread handle not inheritable
        FALSE,          // Set handle inheritance to FALSE
        0,              // No creation flags
        NULL,           // Use parent's environment block
        NULL,           // Use parent's starting directory 
        &si,            // Pointer to STARTUPINFO structure
        &pi )           // Pointer to PROCESS_INFORMATION structure
    ) 
    {
        printf( "CreateProcess failed (%d)\n", GetLastError() );
        return;
    }

   /*     HANDLE  hStdInput;
    HANDLE  hStdOutput;
    HANDLE  hStdError;*/
    HANDLE me_hStdInput = GetStdHandle(STD_INPUT_HANDLE);
    HANDLE me_hStdOutput = GetStdHandle(STD_OUTPUT_HANDLE);
    HANDLE proc_hStdInput = si.hStdInput;
    HANDLE proc_hStdOutput = si.hStdOutput;

                char buff[64];
                DWORD chars;
    while (!ReadConsole(me_hStdInput, buff, sizeof(buff), &chars, NULL))
    {
                    for (DWORD written = 0, writtenThisTime; written < chars; written += writtenThisTime)                   
                        if (!WriteConsole(proc_hStdOutput, buff + written, chars - written, &writtenThisTime, NULL))
                        {
                            //handle error - TODO
                        }
                }
                //possibly handle error for ReadConsole - TODO  


    // Wait until child process exits.
    //WaitForSingleObject( pi.hProcess, INFINITE );

    // Close process and thread handles. 
    CloseHandle( pi.hProcess );
    CloseHandle( pi.hThread );
}
于 2012-06-24T11:04:38.293 に答える