Ruby Examples

ChilkatHOMEAndroid™ASPVisual BasicVB.NETC#iOS (IPhone)Objective-CC++CMFCDelphiFoxProJavaPerl
PHP ExtensionPHP ActiveXPythonPowerShellRubySQL ServerVBScript

Ruby
Examples

Quick Start
Unicode
Byte Array
Bz2
Certificates
CSV
Email
Encryption
FTP
HTML Conversion
HTTP
IMAP
MHT
MIME
POP3
RSA
S/MIME
Signatures
SFTP
SMTP
Socket / SSL
Spider
SSH
SSH Key
SSH Tunnel
Tar
HTTP Upload
XML
XMP
Zip

More Examples...
String
Amazon S3
Email Object
DKIM / DomainKey
NTLM
FileAccess
RSS
Atom
Self-Extractor
Service
PPMD
Deflate
Bzip2
DH Key Exchange
DSA
LZW

 

 

 

 

 

 

 

SFTP Writing utf-8 vs. ANSI Text Files

Demonstrates how to specify the charset, such as utf-8, ANSI, windows-1250, iso-8859-1, Shift_JIS, etc., when writing text files. See the List of Charsets for all supported charsets.

Downloads for Windows/Linux and Install Instructions

require 'rubygems'
require 'chilkat'

#  Important: It is helpful to send the contents of the
#  sftp.LastErrorText property when requesting support.

sftp = Chilkat::CkSFtp.new()

#  Any string automatically begins a fully-functional 30-day trial.
success = sftp.UnlockComponent("Anything for 30-day trial")
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Set some timeouts, in milliseconds:
sftp.put_ConnectTimeoutMs(5000)
sftp.put_IdleTimeoutMs(15000)

#  Connect to the SSH server.
#  The standard SSH port = 22
#  The hostname may be a hostname or IP address.

hostname = "192.168.1.108"
port = 22
success = sftp.Connect(hostname,port)
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Authenticate with the SSH server.  Chilkat SFTP supports
#  both password-based authenication as well as public-key
#  authentication.  This example uses password authenication.
success = sftp.AuthenticatePw("myLogin","myPassword")
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  After authenticating, the SFTP subsystem must be initialized:
success = sftp.InitializeSftp()
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Open a file on the server for writing.
#  "createTruncate" means that a new file is created; if the file already exists, it is opened and truncated.

handle = sftp.openFile("utf8_sample.txt","writeOnly","createTruncate")
if (handle == nil )
    print sftp.lastErrorText() + "\n"
    exit
end

#  Write a single utf-8 character to the file - a lowercase ü
#  A "ü" in utf-8 is represented by 2 bytes:  0xC3 0xBC
#  The following call to WriteFileText writes 2 bytes (0xC3 0xBC)
#  to the file:
success = sftp.WriteFileText(handle,"utf-8","ü")
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Close the file.
success = sftp.CloseHandle(handle)
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Let's write the same "ü" character using windows-1252
#  (which is the ANSI charset for Western-European languages)
handle = sftp.openFile("windows1252_sample.txt","writeOnly","createTruncate")
if (handle == nil )
    print sftp.lastErrorText() + "\n"
    exit
end

#  Write a single windows-1252 character to the file - a lowercase ü
#  A "ü" in windows-1252 is represented by 1 byte:  0xFC
#  The following call to WriteFileText writes 1 byte (0xFC)
#  to the file:
success = sftp.WriteFileText(handle,"windows-1252","ü")
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

#  Close the file.
success = sftp.CloseHandle(handle)
if (success != true)
    print sftp.lastErrorText() + "\n"
    exit
end

print "Success." + "\n"
 

© 2000-2010 Chilkat Software, Inc. All Rights Reserved.