Sample code for 30+ languages & platforms
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

Tcl

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