SQL Server
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
-- 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