Tcl
Tcl
SOCKS4 and SOCKS5 Proxy for FTP
See more FTP Examples
Demonstrates how to connect to an FTP server through a SOCKS4 or SOCKS5 proxy. Both SSL/TLS and non-secure FTP communications may use SOCKS4 and SOCKS5 proxies.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
set ftp [new_CkFtp2]
CkFtp2_put_Hostname $ftp "ftp.example.com"
CkFtp2_put_Username $ftp "login"
CkFtp2_put_Password $ftp "password"
# To use a SOCKS4 or SOCKS5 proxy, simply set the following
# properties prior to connecting:
# The SOCKS hostname may be a domain name or
# IP address:
CkFtp2_put_SocksHostname $ftp "www.mysocksproxyserver.com"
CkFtp2_put_SocksPort $ftp 1080
CkFtp2_put_SocksUsername $ftp "myProxyLogin"
CkFtp2_put_SocksPassword $ftp "myProxyPassword"
# Set the SOCKS version to 4 or 5 based on the version
# of the SOCKS proxy server:
CkFtp2_put_SocksVersion $ftp 5
# Note: SOCKS4 servers only support usernames without passwords.
# SOCKS5 servers support full login/password authentication.
# Connect and login to the FTP server.
set success [CkFtp2_Connect $ftp]
if {$success != 1} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
exit
}
# Change to the remote directory where the file is located.
# This step is only necessary if the file is not in the root directory
# for the FTP account.
set success [CkFtp2_ChangeRemoteDir $ftp "junk"]
if {$success != 1} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
exit
}
# Download a file.
set localFilename "c:/temp/hamlet.xml"
set remoteFilename "hamlet.xml"
set success [CkFtp2_GetFile $ftp $remoteFilename $localFilename]
if {$success != 1} then {
puts [CkFtp2_lastErrorText $ftp]
delete_CkFtp2 $ftp
exit
}
set success [CkFtp2_Disconnect $ftp]
puts "File Downloaded!"
delete_CkFtp2 $ftp