Sample code for 30+ languages & platforms
DataFlex

ConnectFailReason

See more FTP Examples

The ConnectFailReason property can be examined to determine the reason why the Connect method failed. The possible values are listed in the source code below:

Chilkat DataFlex Downloads

DataFlex
Use ChilkatAx-win32.pkg

Procedure Test
    Boolean iSuccess
    Handle hoFtp
    Integer iFailReason
    String sTemp1

    Move False To iSuccess

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    Get Create (RefClass(cComChilkatFtp2)) To hoFtp
    If (Not(IsComObjectCreated(hoFtp))) Begin
        Send CreateComObject of hoFtp
    End

    Set ComHostname Of hoFtp To "ftp.example.com"
    Set ComUsername Of hoFtp To "login"
    Set ComPassword Of hoFtp To "password"

    // Connect and login to the FTP server.
    Get ComConnect Of hoFtp To iSuccess
    If (iSuccess <> True) Begin

        // The possible failure reasons are:
        // 0 = success
        // 
        // Normal (non-TLS) sockets:
        // 1 = empty hostname
        // 2 = DNS lookup failed
        // 3 = DNS timeout
        // 4 = Aborted by application.
        // 5 = Internal failure.
        // 6 = Connect Timed Out
        // 7 = Connect Rejected (or failed for some other reason)
        // 
        // SSL/TLS:
        // 100 = TLS internal error.
        // 101 = Failed to send client hello.
        // 102 = Unexpected handshake message.
        // 103 = Failed to read server hello.
        // 104 = No server certificate.
        // 105 = Unexpected TLS protocol version.
        // 106 = Server certificate verify failed (the server certificate is expired or the cert's signature verification failed).
        // 107 = Unacceptable TLS protocol version.
        // 109 = Failed to read handshake messages.
        // 110 = Failed to send client certificate handshake message.
        // 111 = Failed to send client key exchange handshake message.
        // 112 = Client certificate's private key not accessible.
        // 113 = Failed to send client cert verify handshake message.
        // 114 = Failed to send change cipher spec handshake message.
        // 115 = Failed to send finished handshake message.
        // 116 = Server's Finished message is invalid.
        // 
        // FTP:
        // 200 = Connected, but failed to receive greeting from FTP server.
        // 201 = Failed to do AUTH TLS or AUTH SSL.
        // Protocol/Component:
        // 300 = asynch op in progress
        // 301 = login failure.

        Get ComConnectFailReason Of hoFtp To iFailReason

        Showln "connect fail reason = " iFailReason

        Get ComLastErrorText Of hoFtp To sTemp1
        Showln sTemp1
        Procedure_Return
    End

    // ..


End_Procedure