Sample code for 30+ languages & platforms
SQL Server

HTTP GET with utf-8 URL Encoded Query Params

See more HTTP Examples

Demonstrates how to build URLs where query param values can be either URL encoded from the utf-8 representation, or from another charset such as windows-1252.

Note: This example uses the new DecodeAndAppend method added in Chilkat v9.5.0.87.

Chilkat SQL Server Downloads

SQL Server
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls.
--
CREATE PROCEDURE ChilkatSample
AS
BEGIN
    DECLARE @hr int
    -- Important: Do not use nvarchar(max).  See the warning about using nvarchar(max).
    DECLARE @sTmp0 nvarchar(4000)
    DECLARE @success int
    SELECT @success = 0

    -- We have the string "MÆRSK".

    -- This is the URL encoding of the windows-1252 representation.
    DECLARE @nameWindows1252UrlEncoded nvarchar(4000)
    SELECT @nameWindows1252UrlEncoded = 'M%C6RSK'

    DECLARE @sb1 int
    EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sb1 OUT
    IF @hr <> 0
    BEGIN
        PRINT 'Failed to create ActiveX component'
        RETURN
    END

    EXEC sp_OAMethod @sb1, 'DecodeAndAppend', @success OUT, @nameWindows1252UrlEncoded, 'url', 'windows-1252'

    DECLARE @http int
    EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT

    -- Here's how to send an HTTP GET where the param is the utf-8 representation that is URL encoded.
    -- For example:  https://www.chilkatsoft.com/something?name=M%C3%A6RSK

    DECLARE @sbUrl int
    EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sbUrl OUT

    EXEC sp_OAMethod @sbUrl, 'Append', @success OUT, 'https://www.chilkatsoft.com/something?name='
    EXEC sp_OAMethod @sb1, 'GetEncoded', @sTmp0 OUT, 'url', 'utf-8'
    EXEC sp_OAMethod @sbUrl, 'Append', @success OUT, @sTmp0
    EXEC sp_OAMethod @sbUrl, 'GetAsString', @sTmp0 OUT
    PRINT @sTmp0

    DECLARE @responseBody nvarchar(4000)
    EXEC sp_OAMethod @sbUrl, 'GetAsString', @sTmp0 OUT
    EXEC sp_OAMethod @http, 'QuickGetStr', @responseBody OUT, @sTmp0

    -- Here's how to send an HTTP GET where the param is the windows-1252 representation that is URL encoded.
    -- For example:  https://www.chilkatsoft.com/something?name=M%E6RSK

    EXEC sp_OAMethod @sbUrl, 'Clear', NULL
    EXEC sp_OAMethod @sbUrl, 'Append', @success OUT, 'https://www.chilkatsoft.com/something?name='
    EXEC sp_OAMethod @sb1, 'GetEncoded', @sTmp0 OUT, 'url', 'windows-1252'
    EXEC sp_OAMethod @sbUrl, 'Append', @success OUT, @sTmp0
    EXEC sp_OAMethod @sbUrl, 'GetAsString', @sTmp0 OUT
    PRINT @sTmp0

    EXEC sp_OAMethod @sbUrl, 'GetAsString', @sTmp0 OUT
    EXEC sp_OAMethod @http, 'QuickGetStr', @responseBody OUT, @sTmp0

    EXEC @hr = sp_OADestroy @sb1
    EXEC @hr = sp_OADestroy @http
    EXEC @hr = sp_OADestroy @sbUrl


END
GO