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
(Visual Basic 6.0) Geolocation of IP AddressTo get information about an IP address, there are various public web services that can be queried. I would also guess that paid-for services exist. In any case, it's likely the service is accessible via a REST API. This example demonstrates a few public geolocation API's, each of which may have limitations on the number of queries per hour/day/etc. Also, please note that this example was created on 23-Sep-2016. As time goes by, the public services referenced by this example may have changed or disappeared entirely. Make sure to do your research before assuming this example will work. The intent of this example is to give a flavor of what might be possible.
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' The IP address used in this example is 104.40.211.35 Dim ipAddress As String ipAddress = "104.40.211.35" ' First we'll try the service at freegeoip.net. ' They have a limit of 10,000 queries per hour, and also ' provide free source code to run your own server. Dim rest As New ChilkatRest ' Connect to freegeoip.net Dim bTls As Long bTls = 0 Dim port As Long port = 80 Dim bAutoReconnect As Long bAutoReconnect = 1 Dim success As Long success = rest.Connect("freegeoip.net",port,bTls,bAutoReconnect) If (success = 0) Then Debug.Print rest.LastErrorText Exit Sub End If ' Query the IP address to return JSON. Dim responseJson As String responseJson = rest.FullRequestNoBody("GET","/json/104.40.211.35") If (rest.LastMethodSuccess <> 1) Then Debug.Print rest.LastErrorText Exit Sub End If ' Just in case we are still connected.. Dim maxWaitMs As Long maxWaitMs = 10 success = rest.Disconnect(maxWaitMs) Dim json As New ChilkatJsonObject success = json.Load(responseJson) json.EmitCompact = 0 Debug.Print json.Emit() ' The JSON we get back looks like this: ' { ' "ip": "104.40.211.35", ' "country_code": "US", ' "country_name": "United States", ' "region_code": "WA", ' "region_name": "Washington", ' "city": "Redmond", ' "zip_code": "98052", ' "time_zone": "America/Los_Angeles", ' "latitude": 47.6801, ' "longitude": -122.1206, ' "metro_code": 819 ' } ' Examine a few bits of information: Debug.Print "country name = " & json.StringOf("country_name") Debug.Print "country code = " & json.StringOf("country_code") ' ----------------------------------------------------- ' Now to use ip-api.com, which is mostly the same.. success = rest.Connect("ip-api.com",port,bTls,bAutoReconnect) If (success = 0) Then Debug.Print rest.LastErrorText Exit Sub End If ' Query the IP address to return JSON. responseJson = rest.FullRequestNoBody("GET","/json/104.40.211.35") If (rest.LastMethodSuccess <> 1) Then Debug.Print rest.LastErrorText Exit Sub End If ' Just in case we are still connected.. success = rest.Disconnect(maxWaitMs) success = json.Load(responseJson) json.EmitCompact = 0 Debug.Print json.Emit() ' The JSON we get back looks like this: ' This is very strange, because the two services don't agree. ' { ' "as": "AS8075 Microsoft Corporation", ' "city": "Amsterdam", ' "country": "Netherlands", ' "countryCode": "NL", ' "isp": "Microsoft Corporation", ' "lat": 52.35, ' "lon": 4.9167, ' "org": "Microsoft Azure", ' "query": "104.40.211.35", ' "region": "NH", ' "regionName": "North Holland", ' "status": "success", ' "timezone": "Europe/Amsterdam", ' "zip": "1091" ' } ' Examine a few bits of information: Debug.Print "country name = " & json.StringOf("country") Debug.Print "country code = " & json.StringOf("countryCode") |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.