Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) Send JSON REST Request, Get JSON ResponseDemonstrates sending a RESTful JSON request, and receiving a JSON response. This example will create a bucket in Google Cloud Storage (which involves sending and receiving JSON).
// Important: See this note about string length limitations for strings returned by sp_OAMethod calls. // CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int DECLARE @sTmp0 nvarchar(4000) -- This example will create a bucket in Google Cloud Storage. DECLARE @success int -- It requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @gAuth int EXEC @hr = sp_OACreate 'Chilkat_9_5_0.AuthGoogle', @gAuth OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Obtain an access token as shown in one of the following examples: -- See Get Access Token using a Service Account JSON Key -- See Get Access Token using a P12 File DECLARE @rest int EXEC @hr = sp_OACreate 'Chilkat_9_5_0.Rest', @rest OUT -- Connect using TLS. DECLARE @bAutoReconnect int SELECT @bAutoReconnect = 1 EXEC sp_OAMethod @rest, 'Connect', @success OUT, 'www.googleapis.com', 443, 1, @bAutoReconnect -- Provide the authentication credentials (i.e. the access key) EXEC sp_OAMethod @rest, 'SetAuthGoogle', @success OUT, @gAuth -- Build the JSON request body for creating a bucket. -- The only required property is the "name", but we'll add more -- to make a better example.. DECLARE @jsonReqBody int EXEC @hr = sp_OACreate 'Chilkat_9_5_0.JsonObject', @jsonReqBody OUT EXEC sp_OAMethod @jsonReqBody, 'AddStringAt', @success OUT, -1, 'name', 'chilkat-bucket-c' EXEC sp_OAMethod @jsonReqBody, 'AddStringAt', @success OUT, -1, 'kind', 'storage#bucket' EXEC sp_OAMethod @jsonReqBody, 'AddStringAt', @success OUT, -1, 'location', 'US' EXEC sp_OAMethod @jsonReqBody, 'AddObjectAt', @success OUT, -1, 'versioning' DECLARE @pObjVersioning int EXEC sp_OAMethod @jsonReqBody, 'ObjectOf', @pObjVersioning OUT, 'versioning' EXEC sp_OAMethod @pObjVersioning, 'AddBoolAt', @success OUT, -1, 'enabled', 1 EXEC @hr = sp_OADestroy @pObjVersioning -- Show the HTTP request body we'll be sending. EXEC sp_OAMethod @jsonReqBody, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- Add the required query parameter. -- See https://cloud.google.com/storage/docs/json_api/v1/buckets/insert EXEC sp_OAMethod @rest, 'AddQueryParam', @success OUT, 'project', 'chilkattest-1050' -- Add the Content-Type HTTP request header. EXEC sp_OAMethod @rest, 'AddHeader', @success OUT, 'Content-Type', 'application/json; charset=UTF-8' DECLARE @jsonResponseStr nvarchar(4000) EXEC sp_OAMethod @jsonReqBody, 'Emit', @sTmp0 OUT EXEC sp_OAMethod @rest, 'FullRequestString', @jsonResponseStr OUT, 'POST', '/storage/v1/b', @sTmp0 EXEC sp_OAGetProperty @rest, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN EXEC sp_OAGetProperty @rest, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @gAuth EXEC @hr = sp_OADestroy @rest EXEC @hr = sp_OADestroy @jsonReqBody RETURN END -- Show the JSON response. (See below for a sample JSON response.) PRINT 'Json Response: ' + @jsonResponseStr -- { -- "kind": "storage#bucket", -- "id": "chilkat-bucket-c", -- "selfLink": "https://www.googleapis.com/storage/v1/b/chilkat-bucket-c", -- "projectNumber": "999992999999", -- "name": "chilkat-bucket-c", -- "timeCreated": "2016-04-29T21:08:10.451Z", -- "updated": "2016-04-29T21:08:10.451Z", -- "metageneration": "1", -- "owner": { -- "entity": "project-owners-999992999999" -- }, -- "location": "US", -- "versioning": { -- "enabled": true -- }, -- "storageClass": "STANDARD", -- "etag": "CAE=" -- } -- EXEC @hr = sp_OADestroy @gAuth EXEC @hr = sp_OADestroy @rest EXEC @hr = sp_OADestroy @jsonReqBody END GO |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.