IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Composants VCL Delphi Discussion :

[indy] un ping récalcitrant


Sujet :

Composants VCL Delphi

  1. #1
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 955
    Points
    40 955
    Billets dans le blog
    62
    Par défaut [indy] un ping récalcitrant
    Bonjour,

    J'ai utilisé la faq pour faire un programme test Ping avec Indy sur une adresse locale et sur une adresse www

    Sur tous les postes du réseau (hétérogène en version Windows) j'ai installé le même programme .seul un poste reste récalcitrant
    et pourtant :
    - un ping 'classique' en mode de commande fonctionne
    - le poste est bien visible sur le réseau
    - le poste utilise mes programmes avec BDD sur le serveur
    - le poste va bien sur internet
    j'ai vérifié
    -si l'antivirus (AVAST) pouvait poser un problème (même chose en le désactivant)
    -le parefeu , idem

    Quelles pistes ou solutions me restent-ils ?
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 955
    Points
    40 955
    Billets dans le blog
    62
    Par défaut
    C'est l'UAC qui me bloquait , il va donc me falloir une autre solution que via INDY (c'est dans une des FAQ de Indy que j'ai découvert la cause) !

    IL va sans doute que je passe par l'utilisation de ICMP.DLL comme indiqué ici
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  3. #3
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 955
    Points
    40 955
    Billets dans le blog
    62
    Par défaut toujours bloqué
    la piste ICMP.DLL n'a pas l'air de fonctionner (quelque soit l'adresse , a partir du moment ou c'est une adresse correcte la réponse est OK)

    D'autres pistes (avant que j'explore les WMI) ?
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  4. #4
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Vu que cela fonctionne sur tous les autres postes, cela serait dommage de devoir tous casser pour un seul poste

    N'y a t il pas une différence sur ce poste avec les autres :

    - un programme installé en plus qui pourrait perturber le fonctionnement de ton Ping.
    - Une configuration étrange par rapport aux autres
    - etc ...
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  5. #5
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 955
    Points
    40 955
    Billets dans le blog
    62
    Par défaut
    Citation Envoyé par Rayek Voir le message
    N'y a t il pas une différence sur ce poste avec les autres :
    Si : L' UAC mais voila : comment faire pour bypasser cette dernière sans la désactiver puisque c'est un des problèmes du a Indy

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
     
    procedure TForm15.Button5Click(Sender: TObject);
    function IAddrToHostName(const IP: Ansistring): string;
    var
      i: Integer;
      p: PHostEnt;
    begin
      Result := '';
      i      := inet_addr(PAnsiChar(IP));
      if i <> u_long(INADDR_NONE) then
      begin
        p := GetHostByAddr(@i, SizeOf(Integer), PF_INET);
        if p <> nil then Result := p^.h_name;
      end
      else
        Result := 'Invalid IP address';
    end;
     
    begin
    Showmessage(IAddrToHostName('192.168.0.16'));
    end;
    ceci fonctionne (renvoi pour l'instant blanc) mais est trop long a l'execution
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  6. #6
    Membre chevronné

    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2002
    Messages
    1 288
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Août 2002
    Messages : 1 288
    Points : 1 936
    Points
    1 936
    Par défaut
    J'ai testé rapidement, si c'est pour faire juste un ping ça m'a l'air correct:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
     
    {*_* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
     
    Author:       Franois PIETTE
    Description:  This unit encapsulate the ICMP.DLL into an object of type TICMP.
                  Using this object, you can easily ping any host on your network.
                  Works only in 32 bits mode (no Delphi 1) under NT or 95.
                  TICMP is perfect for a console mode program, but if you build a
                  GUI program, you could use the TPing object wich is a true VCL
                  encapsulating the TICMP object. Then you can use object inspector
                  to change properties or event handler. This is much simpler to
                  use for a GUI program.
    EMail:        http://users.swing.be/francois.piette  francois.piette@swing.be
                  http://www.rtfm.be/fpiette             francois.piette@rtfm.be
                  francois.piette@pophost.eunet.be
    Creation:     January 6, 1997
    Version:      1.04
    Support:      Use the mailing list twsocket@rtfm.be See website for details.
    Legal issues: Copyright (C) 1997-2000 by Franois PIETTE
                  Rue de Grady 24, 4053 Embourg, Belgium. Fax: +32-4-365.74.56
                  <francois.piette@pophost.eunet.be>
     
                  This software is provided 'as-is', without any express or
                  implied warranty.  In no event will the author be held liable
                  for any  damages arising from the use of this software.
     
                  Permission is granted to anyone to use this software for any
                  purpose, including commercial applications, and to alter it
                  and redistribute it freely, subject to the following
                  restrictions:
     
                  1. The origin of this software must not be misrepresented,
                     you must not claim that you wrote the original software.
                     If you use this software in a product, an acknowledgment
                     in the product documentation would be appreciated but is
                     not required.
     
                  2. Altered source versions must be plainly marked as such, and
                     must not be misrepresented as being the original software.
     
                  3. This notice may not be removed or altered from any source
                     distribution.
     
                  4. You must register this software by sending a picture postcard
                     to the author. Use a nice stamp and mention your name, street
                     address, EMail address and any comment you like to say.
     
    Updates:
    Dec 13, 1997 V1.01 Added OnEchoRequest and OnEchoReply events and removed the
                 corresponding OnDisplay event. This require to modify existing
                 programs.
    Mar 15, 1998 V1.02 Deplaced address resolution just before use
    Sep 24, 1998 V1.93 Changed TIPAddr and others to LongInt to avoid range error
                 problems with Delphi 4
    Jan 24, 1999 V1.11 Surfaced Flags property to allow fragmentation check
                 (Flags = IP_FLAG_DF to enable fragmentation check)
     
     
     * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    unit Icmp;
     
    interface
     
    {$IFDEF VER80}
    // This source file is *NOT* compatible with Delphi 1 because it uses
    // Win 32 features.
    {$ENDIF}
     
    uses
      Windows, SysUtils, Classes, WinSock;
     
    const
      IcmpVersion = 102;
      IcmpDLL2     = 'icmp.dll';
      IcmpDLL     = 'Iphlpapi.dll';
     
     
      // IP status codes returned to transports and user IOCTLs.
      IP_SUCCESS                  = 0;
      IP_STATUS_BASE              = 11000;
      IP_BUF_TOO_SMALL            = (IP_STATUS_BASE + 1);
      IP_DEST_NET_UNREACHABLE     = (IP_STATUS_BASE + 2);
      IP_DEST_HOST_UNREACHABLE    = (IP_STATUS_BASE + 3);
      IP_DEST_PROT_UNREACHABLE    = (IP_STATUS_BASE + 4);
      IP_DEST_PORT_UNREACHABLE    = (IP_STATUS_BASE + 5);
      IP_NO_RESOURCES             = (IP_STATUS_BASE + 6);
      IP_BAD_OPTION               = (IP_STATUS_BASE + 7);
      IP_HW_ERROR                 = (IP_STATUS_BASE + 8);
      IP_PACKET_TOO_BIG           = (IP_STATUS_BASE + 9);
      IP_REQ_TIMED_OUT            = (IP_STATUS_BASE + 10);
      IP_BAD_REQ                  = (IP_STATUS_BASE + 11);
      IP_BAD_ROUTE                = (IP_STATUS_BASE + 12);
      IP_TTL_EXPIRED_TRANSIT      = (IP_STATUS_BASE + 13);
      IP_TTL_EXPIRED_REASSEM      = (IP_STATUS_BASE + 14);
      IP_PARAM_PROBLEM            = (IP_STATUS_BASE + 15);
      IP_SOURCE_QUENCH            = (IP_STATUS_BASE + 16);
      IP_OPTION_TOO_BIG           = (IP_STATUS_BASE + 17);
      IP_BAD_DESTINATION          = (IP_STATUS_BASE + 18);
     
      // status codes passed up on status indications.
      IP_ADDR_DELETED             = (IP_STATUS_BASE + 19);
      IP_SPEC_MTU_CHANGE          = (IP_STATUS_BASE + 20);
      IP_MTU_CHANGE               = (IP_STATUS_BASE + 21);
     
      IP_GENERAL_FAILURE          = (IP_STATUS_BASE + 50);
     
      MAX_IP_STATUS               = IP_GENERAL_FAILURE;
     
      IP_PENDING                  = (IP_STATUS_BASE + 255);
     
      // IP header flags
      IP_FLAG_DF                  = $02;         // Don't fragment this packet.
     
      // IP Option Types
      IP_OPT_EOL                  = $00;         // End of list option
      IP_OPT_NOP                  = $01;         // No operation
      IP_OPT_SECURITY             = $82;         // Security option.
      IP_OPT_LSRR                 = $83;         // Loose source route.
      IP_OPT_SSRR                 = $89;         // Strict source route.
      IP_OPT_RR                   = $07;         // Record route.
      IP_OPT_TS                   = $44;         // Timestamp.
      IP_OPT_SID                  = $88;         // Stream ID (obsolete)
      MAX_OPT_SIZE                = $40;
     
    type
      // IP types
      TIPAddr   = LongInt;   // An IP address.
      TIPMask   = LongInt;   // An IP subnet mask.
      TIPStatus = LongInt;   // Status code returned from IP APIs.
     
      PIPOptionInformation = ^TIPOptionInformation;
      TIPOptionInformation = packed record
         TTL:         Byte;      // Time To Live (used for traceroute)
         TOS:         Byte;      // Type Of Service (usually 0)
         Flags:       Byte;      // IP header flags (usually 0)
         OptionsSize: Byte;      // Size of options data (usually 0, max 40)
         OptionsData: PChar;     // Options data buffer
      end;
     
      PIcmpEchoReply = ^TIcmpEchoReply;
      TIcmpEchoReply = packed record
         Address:       TIPAddr;              // Replying address
         Status:        DWord;                // IP status value
         RTT:           DWord;                // Round Trip Time in milliseconds
         DataSize:      Word;                 // Reply data size
         Reserved:      Word;                 // Reserved
         Data:          Pointer;              // Pointer to reply data buffer
         Options:       TIPOptionInformation; // Reply options
      end;
     
      // IcmpCreateFile:
      //     Opens a handle on which ICMP Echo Requests can be issued.
      // Arguments:
      //     None.
      // Return Value:
      //     An open file handle or INVALID_HANDLE_VALUE. Extended error information
      //     is available by calling GetLastError().
      TIcmpCreateFile  = function: THandle; stdcall;
     
      // IcmpCloseHandle:
      //     Closes a handle opened by ICMPOpenFile.
      // Arguments:
      //     IcmpHandle  - The handle to close.
      // Return Value:
      //     TRUE if the handle was closed successfully, otherwise FALSE. Extended
      //     error information is available by calling GetLastError().
      TIcmpCloseHandle = function(IcmpHandle: THandle): Boolean; stdcall;
     
      // IcmpSendEcho:
      //     Sends an ICMP Echo request and returns one or more replies. The
      //     call returns when the timeout has expired or the reply buffer
      //     is filled.
      // Arguments:
      //     IcmpHandle         - An open handle returned by ICMPCreateFile.
      //     DestinationAddress - The destination of the echo request.
      //     RequestData        - A buffer containing the data to send in the
      //                          request.
      //     RequestSize        - The number of bytes in the request data buffer.
      //     RequestOptions     - Pointer to the IP header options for the request.
      //                          May be NULL.
      //     ReplyBuffer        - A buffer to hold any replies to the request.
      //                          On return, the buffer will contain an array of
      //                          ICMP_ECHO_REPLY structures followed by options
      //                          and data. The buffer should be large enough to
      //                          hold at least one ICMP_ECHO_REPLY structure
      //                          and 8 bytes of data - this is the size of
      //                          an ICMP error message.
      //     ReplySize          - The size in bytes of the reply buffer.
      //     Timeout            - The time in milliseconds to wait for replies.
      // Return Value:
      //     Returns the number of replies received and stored in ReplyBuffer. If
      //     the return value is zero, extended error information is available
      //     via GetLastError().
      TIcmpSendEcho    = function(IcmpHandle:          THandle;
                                  DestinationAddress:  TIPAddr;
                                  RequestData:         Pointer;
                                  RequestSize:         Word;
                                  RequestOptions:      PIPOptionInformation;
                                  ReplyBuffer:         Pointer;
                                  ReplySize:           DWord;
                                  Timeout:             DWord
                                 ): DWord; stdcall;
     
      // Event handler type declaration for TICMP.OnDisplay event.
      TICMPDisplay = procedure(Sender: TObject; Msg : String) of object;
      TICMPReply   = procedure(Sender: TObject; Error : Integer) of object;
     
      // The object wich encapsulate the ICMP.DLL
      TICMP = class(TObject)
      private
        hICMPdll :        HModule;                    // Handle for ICMP.DLL
        IcmpCreateFile :  TIcmpCreateFile;
        IcmpCloseHandle : TIcmpCloseHandle;
        IcmpSendEcho :    TIcmpSendEcho;
        hICMP :           THandle;                    // Handle for the ICMP Calls
        FReply :          TIcmpEchoReply;             // ICMP Echo reply buffer
        FAddress :        String;                     // Address given
        FHostName :       String;                     // Dotted IP of host (output)
        FHostIP :         String;                     // Name of host      (Output)
        FIPAddress :      TIPAddr;                    // Address of host to contact
        FSize :           Integer;                    // Packet size (default to 56)
        FTimeOut :        Integer;                    // Timeout (default to 4000mS)
        FTTL :            Integer;                    // Time To Live (for send)
        FFlags :          Integer;                    // Options flags
        FOnDisplay :      TICMPDisplay;               // Event handler to display
        FOnEchoRequest :  TNotifyEvent;
        FOnEchoReply :    TICMPReply;
        FLastError :      DWORD;                      // After sending ICMP packet
        FAddrResolved :   Boolean;
        procedure ResolveAddr;
      public
        constructor Create; virtual;
        destructor  Destroy; override;
        function    Ping : Integer;
        procedure   SetAddress(Value : String);
        function    GetErrorString : String;
     
        property Address       : String         read  FAddress   write SetAddress;
        property Size          : Integer        read  FSize      write FSize;
        property Timeout       : Integer        read  FTimeout   write FTimeout;
        property Reply         : TIcmpEchoReply read  FReply;
        property TTL           : Integer        read  FTTL       write FTTL;
        Property Flags         : Integer        read  FFlags     write FFlags;
        property ErrorCode     : DWORD          read  FLastError;
        property ErrorString   : String         read  GetErrorString;
        property HostName      : String         read  FHostName;
        property HostIP        : String         read  FHostIP;
        property OnDisplay     : TICMPDisplay   read  FOnDisplay write FOnDisplay;
        property OnEchoRequest : TNotifyEvent   read  FOnEchoRequest
                                                write FOnEchoRequest;
        property OnEchoReply   : TICMPReply     read  FOnEchoReply
                                                write FOnEchoReply;
      end;
     
      TICMPException = class(Exception);
     
    implementation
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    constructor TICMP.Create;
    var
        WSAData: TWSAData;
    begin
        hICMP    := INVALID_HANDLE_VALUE;
        FSize    := 56;
        FTTL     := 64;
        FTimeOut := 4000;
     
        // initialise winsock
        if WSAStartup($101, WSAData) <> 0 then
            raise TICMPException.Create('Error initialising Winsock');
     
        // register the icmp.dll stuff
        hICMPdll := LoadLibrary(icmpDLL);
        if hICMPdll = 0 then
            raise TICMPException.Create('Unable to register ' + icmpDLL);
     
        @ICMPCreateFile  := GetProcAddress(hICMPdll, 'IcmpCreateFile');
        @IcmpCloseHandle := GetProcAddress(hICMPdll, 'IcmpCloseHandle');
        @IcmpSendEcho    := GetProcAddress(hICMPdll, 'IcmpSendEcho');
     
        if (@ICMPCreateFile = Nil) or
           (@IcmpCloseHandle = Nil) or
           (@IcmpSendEcho = Nil) then
              raise TICMPException.Create('Error loading dll functions');
     
        hICMP := IcmpCreateFile;
        if hICMP = INVALID_HANDLE_VALUE then
            raise TICMPException.Create('Unable to get ping handle');
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    destructor TICMP.Destroy;
    begin
        if hICMP <> INVALID_HANDLE_VALUE then
            IcmpCloseHandle(hICMP);
        if hICMPdll <> 0 then
            FreeLibrary(hICMPdll);
        WSACleanup;
        inherited Destroy;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    function MinInteger(X, Y: Integer): Integer;
    begin
        if X >= Y then
            Result := Y
        else
            Result := X;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    procedure TICMP.ResolveAddr;
    var
        Phe : PHostEnt;             // HostEntry buffer for name lookup
    begin
        // Convert host address to IP address
        FIPAddress := inet_addr(PChar(FAddress));
        if FIPAddress <> LongInt(INADDR_NONE) then
            // Was a numeric dotted address let it in this format
            FHostName := FAddress
        else begin
            // Not a numeric dotted address, try to resolve by name
            Phe := GetHostByName(PChar(FAddress));
            if Phe = nil then begin
                FLastError := GetLastError;
                if Assigned(FOnDisplay) then
                    FOnDisplay(Self, 'Unable to resolve ' + FAddress);
                Exit;
            end;
     
            FIPAddress := longint(plongint(Phe^.h_addr_list^)^);
            FHostName  := Phe^.h_name;
        end;
     
        FHostIP       := StrPas(inet_ntoa(TInAddr(FIPAddress)));
        FAddrResolved := TRUE;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    procedure TICMP.SetAddress(Value : String);
    begin
        // Only change if needed (could take a long time)
        if FAddress = Value then
            Exit;
        FAddress      := Value;
        FAddrResolved := FALSE;
    //    ResolveAddr;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    function TICMP.GetErrorString : String;
    begin
        case FLastError of
        IP_SUCCESS:               Result := 'No error';
        IP_BUF_TOO_SMALL:         Result := 'Buffer too small';
        IP_DEST_NET_UNREACHABLE:  Result := 'Destination network unreachable';
        IP_DEST_HOST_UNREACHABLE: Result := 'Destination host unreachable';
        IP_DEST_PROT_UNREACHABLE: Result := 'Destination protocol unreachable';
        IP_DEST_PORT_UNREACHABLE: Result := 'Destination port unreachable';
        IP_NO_RESOURCES:          Result := 'No resources';
        IP_BAD_OPTION:            Result := 'Bad option';
        IP_HW_ERROR:              Result := 'Hardware error';
        IP_PACKET_TOO_BIG:        Result := 'Packet too big';
        IP_REQ_TIMED_OUT:         Result := 'Request timed out';
        IP_BAD_REQ:               Result := 'Bad request';
        IP_BAD_ROUTE:             Result := 'Bad route';
        IP_TTL_EXPIRED_TRANSIT:   Result := 'TTL expired in transit';
        IP_TTL_EXPIRED_REASSEM:   Result := 'TTL expired in reassembly';
        IP_PARAM_PROBLEM:         Result := 'Parameter problem';
        IP_SOURCE_QUENCH:         Result := 'Source quench';
        IP_OPTION_TOO_BIG:        Result := 'Option too big';
        IP_BAD_DESTINATION:       Result := 'Bad Destination';
        IP_ADDR_DELETED:          Result := 'Address deleted';
        IP_SPEC_MTU_CHANGE:       Result := 'Spec MTU change';
        IP_MTU_CHANGE:            Result := 'MTU change';
        IP_GENERAL_FAILURE:       Result := 'General failure';
        IP_PENDING:               Result := 'Pending';
        else
            Result := 'ICMP error #' + IntToStr(FLastError);
        end;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    function TICMP.Ping : Integer;
    var
      BufferSize:        Integer;
      pReqData, pData:   Pointer;
      pIPE:              PIcmpEchoReply;       // ICMP Echo reply buffer
      IPOpt:             TIPOptionInformation; // IP Options for packet to send
      Msg:               String;
    begin
        Result     := 0;
        FLastError := 0;
     
        if not FAddrResolved then
            ResolveAddr;
     
        if FIPAddress = LongInt(INADDR_NONE) then begin
            FLastError := IP_BAD_DESTINATION;
            if Assigned(FOnDisplay) then
                FOnDisplay(Self, 'Invalid host address');
            Exit;
        end;
     
        // Allocate space for data buffer space
        BufferSize := SizeOf(TICMPEchoReply) + FSize;
        GetMem(pReqData, FSize);
        GetMem(pData,    FSize);
        GetMem(pIPE,     BufferSize);
     
        try
            // Fill data buffer with some data bytes
            FillChar(pReqData^, FSize, $20);
            Msg := 'Pinging from Delphi code written by F. Piette';
            Move(Msg[1], pReqData^, MinInteger(FSize, Length(Msg)));
     
            pIPE^.Data := pData;
            FillChar(pIPE^, SizeOf(pIPE^), 0);
     
            if Assigned(FOnEchoRequest) then
                FOnEchoRequest(Self);
     
            FillChar(IPOpt, SizeOf(IPOpt), 0);
            IPOpt.TTL   := FTTL;
            IPOpt.Flags := FFlags;
            Result      := IcmpSendEcho(hICMP, FIPAddress, pReqData, FSize,
                                        @IPOpt, pIPE, BufferSize, FTimeOut);
            FLastError  := GetLastError;
            FReply      := pIPE^;
     
            if Assigned(FOnEchoReply) then
                FOnEchoReply(Self, Result);
        finally
            // Free those buffers
            FreeMem(pIPE);
            FreeMem(pData);
            FreeMem(pReqData);
        end;
    end;
     
     
    {* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *}
    end.
    J'ai essayé avec Iphlpapi.dll (comme indiqué dans MSDN), avec un timeout de 100ms. Il faudrait l'adapter pour s'il ne trouve pas Iphlpapi.dll, il cherche icmp.dll;
    Delphi 7/XE2/XE3
    C#
    Oracle 9i à 12c
    SQL Server 2008 à 2014

  7. #7
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 955
    Points
    40 955
    Billets dans le blog
    62
    Par défaut
    Merci à Linkin , icmp était LA solution que tous les postes tests accepte
    (XP,Vista,Seven)
    Un regret tout de même , ce petit problème d'INDY avec l'UAC .
    J'ai l'impression d'utiliser un marteau (une unité) pour écraser un microbe (un ping avec UAC actif) ^^
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Du ping sans Indy et sans etre admin
    Par Danfas2 dans le forum Web & réseau
    Réponses: 5
    Dernier message: 13/05/2013, 10h07
  2. Ping et composant Indy
    Par GO dans le forum Composants VCL
    Réponses: 5
    Dernier message: 24/06/2009, 10h22
  3. Réponses: 3
    Dernier message: 26/07/2002, 23h02
  4. [Kylix] indy sur kylix? pb :-(
    Par NicoLinux dans le forum EDI
    Réponses: 7
    Dernier message: 15/05/2002, 23h32
  5. [Kylix] Runtime error 230 avec INDY
    Par Anonymous dans le forum EDI
    Réponses: 2
    Dernier message: 23/03/2002, 11h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo