Tcl
Tcl
FTP Connect, Examine Server Certificate, and then Authenticate
See more FTP Examples
Demonstrates how to connect to an FTP server, examine the server's SSL/TLS certificate, and then, if it meets the application's security requirements, proceed to authenticate.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example assumes Chilkat Ftp2 to have been previously unlocked.
# See Unlock Ftp2 for sample code.
set ftp [new_CkFtp2]
CkFtp2_put_Hostname $ftp "www.authtls-ftps-server.com"
CkFtp2_put_Username $ftp "FTP_LOGIN"
CkFtp2_put_Password $ftp "FTP_PASSWORD"
CkFtp2_put_AuthTls $ftp 1
CkFtp2_put_Port $ftp 21
# Connect to the FTP server using explicit TLS (AUTH TLS).
set success [CkFtp2_ConnectOnly $ftp]
if {$success == 0} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
exit
}
# Get the FTP server's certificate.
set serverCert [new_CkCert]
set success [CkFtp2_GetServerCert $ftp $serverCert]
if {$success == 0} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
delete_CkCert $serverCert
exit
}
# Now that we have the certificate, we can check it in any way we desire.
# (See the online reference documentation for the certificate object's methods
# and properties)...
# Assuming the certificate is OK, proceed to authenticate with the FTP server.
set success [CkFtp2_LoginAfterConnectOnly $ftp]
if {$success == 0} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
delete_CkCert $serverCert
exit
}
#
# Proceed with uploading/download files, etc...
#
CkFtp2_Disconnect $ftp
puts "Success."
delete_CkFtp2 $ftp
delete_CkCert $serverCert