SQL Server Stored Procedure Examples

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

SQL Server
Stored Procedure Examples

Quick Start
Encryption
File Access
IMAP
POP3
SMTP
Email Object
DKIM / DomainKey
FTP
HTML Conversion
HTTP
MHT
MIME
NTLM
RSA
Diffie-Hellman
DSA
Socket
Spider
SSH Key
SSH
SSH Tunnel
SFTP
String
Tar
Upload
XML
XMP
Zip

Amazon S3
Bz2
CSV
FileAccess
Byte Array
RSS
Atom
Self-Extractor

SSL Server Example

Demonstrates how to create an SSL socket for accepting connections. This example is *very* simple in that it will create an SSL socket for accepting a single connection. It will read a message from the client, send a reply, and exit.

Download Chilkat Socket ActiveX

CREATE PROCEDURE ChilkatSample
AS
BEGIN
    DECLARE @hr int
    DECLARE @sTmp0 nvarchar(4000)
    DECLARE @listenSslSocket int
    EXEC @hr = sp_OACreate 'Chilkat.Socket', @listenSslSocket OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    --  Any string automatically begins a fully-functional 30-day trial.
    DECLARE @success int

    EXEC sp_OAMethod @listenSslSocket, 'UnlockComponent', @success OUT, 'Anything for 30-day trial'
    IF @success <> 1
      BEGIN
        PRINT 'Failed to unlock component'
        RETURN
      END

    --  An SSL server needs a digital certificate.  This example loads it from a PFX file.

    --  Create an instance of a certificate store object, load a PFX file,
    --  locate the certificate we need, and use it.
    --  (a PFX file may contain more than one certificate.)
    DECLARE @certStore int
    EXEC @hr = sp_OACreate 'Chilkat.CertStore', @certStore OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    --  The 1st argument is the filename, the 2nd arg is the
    --  PFX file's password:
    EXEC sp_OAMethod @certStore, 'LoadPfxFile', @success OUT, 'chilkat.pfx', 'test'
    IF @success <> 1
      BEGIN
        EXEC sp_OAGetProperty @certStore, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  Find the certificate to be used for SSL:
    DECLARE @cert int

    EXEC sp_OAMethod @certStore, 'FindCertBySubject', @cert OUT, 'Chilkat Software, Inc.'
    IF @cert Is NULL 
      BEGIN
        EXEC sp_OAGetProperty @certStore, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  Use the certificate:
    EXEC sp_OAMethod @listenSslSocket, 'InitSslServer', @success OUT, @cert
    IF @success <> 1
      BEGIN
        EXEC sp_OAGetProperty @listenSslSocket, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  Bind and listen on a port:
    DECLARE @myPort int

    SELECT @myPort = 8123
    --  Allow for a max of 5 queued connect requests.
    DECLARE @backLog int

    SELECT @backLog = 5
    EXEC sp_OAMethod @listenSslSocket, 'BindAndListen', @success OUT, @myPort, @backLog
    IF @success <> 1
      BEGIN
        EXEC sp_OAGetProperty @listenSslSocket, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  If accepting an SSL/TLS connection, the SSL handshake is part of the connection
    --  establishment process. This involves a few back-and-forth messages between the
    --  client and server to establish algorithms and a shared key to create the secure
    --  channel. The sending and receiving of these messages are governed by the
    --  MaxReadIdleMs and MaxSendIdleMs properties. If these properties are set to 0
    --  (and this is the default unless changed by your application), then the
    --  AcceptNextConnection can hang indefinitely during the SSL handshake process.
    --  Make sure these properties are set to appropriate values before calling AcceptNextConnection.

    --  Set a 10 second max for waiting to read/write.  This is for the SSL/TLS handshake establishment.
    EXEC sp_OASetProperty @listenSslSocket, 'MaxReadIdleMs', 10000
    EXEC sp_OASetProperty @listenSslSocket, 'MaxSendIdleMs', 10000

    --  Accept a single client connection and establish the secure SSL/TLS channel:
    DECLARE @clientSock int

    DECLARE @maxWaitMillisec int

    SELECT @maxWaitMillisec = 20000
    EXEC sp_OAMethod @listenSslSocket, 'AcceptNextConnection', @clientSock OUT, @maxWaitMillisec
    IF @clientSock Is NULL 
      BEGIN
        EXEC sp_OAGetProperty @listenSslSocket, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  The client (in this example) is going to send a "Hello Server! -EOM-"
    --  message.  Read it:
    DECLARE @receivedMsg nvarchar(4000)

    EXEC sp_OAMethod @clientSock, 'ReceiveUntilMatch', @receivedMsg OUT, '-EOM-'
    IF @receivedMsg Is NULL 
      BEGIN
        EXEC sp_OAGetProperty @clientSock, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    PRINT @receivedMsg

    --  Send a "Hello Client! -EOM-" message:
    EXEC sp_OAMethod @clientSock, 'SendString', @success OUT, 'Hello Client! -EOM-'
    IF @success <> 1
      BEGIN
        EXEC sp_OAGetProperty @clientSock, 'LastErrorText', @sTmp0 OUT
        PRINT @sTmp0
        RETURN
      END

    --  Close the connection with the client
    --  Wait a max of 20 seconds (20000 millsec)
    EXEC sp_OAMethod @clientSock, 'Close', NULL, 20000
END
GO

 

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