HOWTO: 응용 대상 확인 여부 과 프로그램을 콘솔 또는 GUI. 방법

중요: 본 문서는 전문 번역가가 번역한 것이 아니라 Microsoft 기계 번역 소프트웨어로 번역한 것입니다. Microsoft는 번역가가 번역한 문서 및 기계 번역된 문서를 모두 제공하므로 Microsoft 기술 자료에 있는 모든 문서를 한글로 접할 수 있습니다. 그러나 기계 번역 문서가 항상 완벽한 것은 아닙니다. 따라서 기계 번역 문서에는 마치 외국인이 한국어로 말할 때 실수를 하는 것처럼 어휘, 구문 또는 문법에 오류가 있을 수 있습니다. Microsoft는 내용상의 오역 또는 Microsoft 고객이 이러한 오역을 사용함으로써 발생하는 부 정확성, 오류 또는 손해에 대해 책임을 지지 않습니다. Microsoft는 이러한 문제를 해결하기 위해 기계 번역 소프트웨어를 자주 업데이트하고 있습니다.

90493
이 문서가 보관되었습니다. "그대로" 제공되었으며, 업데이트가 되지 않을 것입니다.
요약
응용 프로그램이 콘솔 또는 GUI 여부를 확인할 수 있는 EXEheader 구문 분석해야 합니다. 머리글 '하위 시스템' 라는 필드가 들어 있습니다. 이 필드는 응용 프로그램이 실행될 것입니다 하위 시스템과 필요한 인터페이스 유형을 결정합니다. 값이 구성됩니다:
   IMAGE_SUBSYSTEM_NATIVE               1   IMAGE_SUBSYSTEM_WINDOWS_GUI          2   IMAGE_SUBSYSTEM_WINDOWS_CUI          3   IMAGE_SUBSYSTEM_OS2_CUI              5   IMAGE_SUBSYSTEM_POSIX_CUI            7   IMAGE_SUBSYSTEM_NATIVE_WINDOWS       8   IMAGE_SUBSYSTEM_WINDOWS_CE_GUI       9				
추가 정보

예제 코드

#include <windows.h>#include <winnt.h>VOID  main(int, char **);DWORD AbsoluteSeek(HANDLE, DWORD);VOID  ReadBytes(HANDLE, LPVOID, DWORD);VOID  WriteBytes(HANDLE, LPVOID, DWORD);VOID  CopySection(HANDLE, HANDLE, DWORD);#define XFER_BUFFER_SIZE 2048VOIDmain(int argc, char *argv[]){    HANDLE hImage;    DWORD  bytes;    DWORD  iSection;    DWORD  SectionOffset;    DWORD  CoffHeaderOffset;    DWORD  MoreDosHeader[16];    ULONG  ntSignature;    IMAGE_DOS_HEADER      image_dos_header;    IMAGE_FILE_HEADER     image_file_header;    IMAGE_OPTIONAL_HEADER image_optional_header;    IMAGE_SECTION_HEADER  image_section_header;    if (argc != 2)    {        printf("USAGE: %s program_file_name\n", argv[1]);        exit(1);    }    /*     *  Open the reference file.     */     hImage = CreateFile(argv[1],                        GENERIC_READ,                        FILE_SHARE_READ,                        NULL,                        OPEN_EXISTING,                        FILE_ATTRIBUTE_NORMAL,                        NULL);    if (INVALID_HANDLE_VALUE == hImage)    {        printf("Could not open %s, error %lu\n", argv[1], GetLastError());        exit(1);    }    /*     *  Read the MS-DOS image header.     */     ReadBytes(hImage,              &image_dos_header,              sizeof(IMAGE_DOS_HEADER));    if (IMAGE_DOS_SIGNATURE != image_dos_header.e_magic)    {        printf("Sorry, I do not understand this file.\n");        exit(1);    }    /*     *  Read more MS-DOS header.       */     ReadBytes(hImage,              MoreDosHeader,              sizeof(MoreDosHeader));    /*     *  Get actual COFF header.     */     CoffHeaderOffset = AbsoluteSeek(hImage, image_dos_header.e_lfanew) +                       sizeof(ULONG);    ReadBytes (hImage, &ntSignature, sizeof(ULONG));    if (IMAGE_NT_SIGNATURE != ntSignature)    {     printf("Missing NT signature. Unknown file type.\n");     exit(1);    }    SectionOffset = CoffHeaderOffset + IMAGE_SIZEOF_FILE_HEADER +                    IMAGE_SIZEOF_NT_OPTIONAL_HEADER;    ReadBytes(hImage,              &image_file_header,              IMAGE_SIZEOF_FILE_HEADER);    /*     *  Read optional header.     */     ReadBytes(hImage,              &image_optional_header,              IMAGE_SIZEOF_NT_OPTIONAL_HEADER);    switch (image_optional_header.Subsystem)    {    case IMAGE_SUBSYSTEM_UNKNOWN:        printf("Type is unknown.\n");        break;    case IMAGE_SUBSYSTEM_NATIVE:        printf("Type is native.\n");        break;    case IMAGE_SUBSYSTEM_WINDOWS_GUI:        printf("Type is Windows GUI.\n");        break;    case IMAGE_SUBSYSTEM_WINDOWS_CUI:        printf("Type is Windows CUI.\n");        break;    case IMAGE_SUBSYSTEM_OS2_CUI:        printf("Type is OS/2 CUI.\n");        break;    case IMAGE_SUBSYSTEM_POSIX_CUI:        printf("Type is POSIX CUI.\n");        break;    case IMAGE_SUBSYSTEM_NATIVE_WINDOWS:           printf("Type is native Win9x driver.\n");           break;       case IMAGE_SUBSYSTEM_WINDOWS_CE_GUI:           printf("Type is Windows CE.\n");           break;    default:        printf("Unknown type %u.\n", image_optional_header.Subsystem);        break;    }}DWORDAbsoluteSeek(HANDLE hFile,             DWORD  offset){    DWORD newOffset;    if ((newOffset = SetFilePointer(hFile,                                    offset,                                    NULL,                                    FILE_BEGIN)) == 0xFFFFFFFF)    {        printf("SetFilePointer failed, error %lu.\n", GetLastError());        exit(1);    }    return newOffset;}VOIDReadBytes(HANDLE hFile,          LPVOID buffer,          DWORD  size){    DWORD bytes;    if (!ReadFile(hFile,                  buffer,                  size,                  &bytes,                  NULL))    {        printf("ReadFile failed, error %lu.\n", GetLastError());        exit(1);    }    else if (size != bytes)    {        printf("Read the wrong number of bytes, expected %lu, got %lu.\n",               size, bytes);        exit(1);    }}				
3.10 3.50

경고: 이 문서는 자동으로 번역되었습니다.

속성

문서 ID: 90493 - 마지막 검토: 02/27/2014 13:26:31 - 수정: 3.2

Microsoft Win32 Application Programming Interface

  • kbnosurvey kbarchive kbmt kbconsole kbhowto kbkernbase KB90493 KbMtko
피드백