Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) ip-api.com IPv4 Geolocation LookupDemonstrates how to lookup Geolocation data for an IPv4 address using the ip-api.com API.
-- 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 -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. DECLARE @http int -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Lookup an IPv4 address: 149.250.207.170 (this was a randomly chosen address) DECLARE @jsonStr nvarchar(4000) EXEC sp_OAMethod @http, 'QuickGetStr', @jsonStr OUT, 'http://ip-api.com/json/149.250.207.170' EXEC sp_OAGetProperty @http, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 = 0 BEGIN EXEC sp_OAGetProperty @http, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @http RETURN END DECLARE @json int -- Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.JsonObject', @json OUT EXEC sp_OASetProperty @json, 'EmitCompact', 0 DECLARE @success int EXEC sp_OAMethod @json, 'Load', @success OUT, @jsonStr EXEC sp_OAMethod @json, 'Emit', @sTmp0 OUT PRINT @sTmp0 -- Sample output: -- Use this online tool to generate parsing code from sample JSON: -- Generate Parsing Code from JSON -- { -- "as": "AS15854 Hewlett Packard GmbH", -- "city": "B�blingen", -- "country": "Germany", -- "countryCode": "DE", -- "isp": "Triaton Frankfurt", -- "lat": 48.6779, -- "lon": 8.97297, -- "org": "EntServ Deutschland GmbH", -- "query": "149.250.207.170", -- "region": "BW", -- "regionName": "Baden-W�rttemberg", -- "status": "success", -- "timezone": "Europe/Berlin", -- "zip": "71034" -- } DECLARE @as nvarchar(4000) DECLARE @city nvarchar(4000) DECLARE @country nvarchar(4000) DECLARE @countryCode nvarchar(4000) DECLARE @isp nvarchar(4000) DECLARE @lat nvarchar(4000) DECLARE @lon nvarchar(4000) DECLARE @org nvarchar(4000) DECLARE @query nvarchar(4000) DECLARE @region nvarchar(4000) DECLARE @regionName nvarchar(4000) DECLARE @status nvarchar(4000) DECLARE @timezone nvarchar(4000) DECLARE @zip nvarchar(4000) EXEC sp_OAMethod @json, 'StringOf', @as OUT, 'as' EXEC sp_OAMethod @json, 'StringOf', @city OUT, 'city' EXEC sp_OAMethod @json, 'StringOf', @country OUT, 'country' EXEC sp_OAMethod @json, 'StringOf', @countryCode OUT, 'countryCode' EXEC sp_OAMethod @json, 'StringOf', @isp OUT, 'isp' EXEC sp_OAMethod @json, 'StringOf', @lat OUT, 'lat' EXEC sp_OAMethod @json, 'StringOf', @lon OUT, 'lon' EXEC sp_OAMethod @json, 'StringOf', @org OUT, 'org' EXEC sp_OAMethod @json, 'StringOf', @query OUT, 'query' EXEC sp_OAMethod @json, 'StringOf', @region OUT, 'region' EXEC sp_OAMethod @json, 'StringOf', @regionName OUT, 'regionName' EXEC sp_OAMethod @json, 'StringOf', @status OUT, 'status' EXEC sp_OAMethod @json, 'StringOf', @timezone OUT, 'timezone' EXEC sp_OAMethod @json, 'StringOf', @zip OUT, 'zip' EXEC @hr = sp_OADestroy @http EXEC @hr = sp_OADestroy @json END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.