Chilkat  HOME  Android™  Classic ASP  C  C++  C#  Mono C#  .NET Core C#  C# UWP/WinRT  DataFlex  Delphi ActiveX  Delphi DLL  Visual FoxPro  Java  Lianja  MFC  Objective-C  Perl  PHP ActiveX  PHP Extension  PowerBuilder  PowerShell  PureBasic  CkPython  Chilkat2-Python  Ruby  SQL Server  Swift 2  Swift 3,4,5...  Tcl  Unicode C  Unicode C++  Visual Basic 6.0  VB.NET  VB.NET UWP/WinRT  VBScript  Xojo Plugin  Node.js  Excel  Go
 
      (Excel) 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 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 Chilkat.Rest Set rest = Chilkat.NewRest ' Connect to freegeoip.net bTls = False port = 80 bAutoReconnect = True success = rest.Connect("freegeoip.net",port,bTls,bAutoReconnect) If (success = False) 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 <> True) Then Debug.Print rest.LastErrorText Exit Sub End If ' Just in case we are still connected.. maxWaitMs = 10 Dim success As Boolean success = rest.Disconnect(maxWaitMs) Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.Load(responseJson) json.EmitCompact = False 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 = False) 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 <> True) 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 = False 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-2022 Chilkat Software, Inc. All Rights Reserved.