Comment faire : Comment faire pour déterminer si une application est console ou de graphique

IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d’articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d’avoir accès, dans votre propre langue, à l’ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s’exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s’efforce aussi continuellement de faire évoluer son système de traduction automatique.

90493
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Résumé
Afin de déterminer si une application est console ou de graphique, vous devez analyser le EXEheader. L'en-tête contient un champ intitulé « sous-système ». Ce champ détermine à la fois le sous-système de que l'application doit s'exécuter sous et le type d'interface qu'il nécessite. Les valeurs sont :
   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				
Plus d'informations

Exemple de code

#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

Avertissement : Cet article a été traduit de manière automatique

Propriétés

ID d'article : 90493 - Dernière mise à jour : 02/27/2014 13:26:31 - Révision : 3.2

  • Microsoft Win32 Application Programming Interface
  • kbnosurvey kbarchive kbmt kbconsole kbhowto kbkernbase KB90493 KbMtfr
Commentaires