简介

很多时候,我们获取了用户ip,但是想知道更多信息,怎么办?使用ip2location吧。

这个库,可以从IP地址快速查找国家,地区,城市,纬度,经度,邮政编码,时区,ISP,域名,连接类型,IDD代码,地区代码 等各种信息。
它使用IP2Location.com上提供的基于文件的数据库,该数据库是以ip为key,国家/城市/经纬度等信息为value 的一个映射表。

快速使用

步骤如下

  1. IP2Location.com下载文件数据库到本地
  2. 加载文件数据库到代码
  3. 调用函数获取 国家/城市/经纬度 等数据

1. 按需函数调用

在项目中,需要从ip中获取国家、地区、经纬度等信息时候,直接调用对应函数,可以获取相应数值。

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/ip2location/ip2location-go"
  5. )
  6. func main() {
  7. ip := "8.8.8.8"
  8. ip2location.Open("./IP2LOCATION-LITE-DB5.BIN")
  9. country := ip2location.Get_country_long(ip)
  10. region := ip2location.Get_region(ip)
  11. city := ip2location.Get_city(ip)
  12. latitude := ip2location.Get_latitude(ip)
  13. longitude := ip2location.Get_longitude(ip)
  14. fmt.Printf("country: %s\n", country.Country_long)
  15. fmt.Printf("region: %s\n", region.Region)
  16. fmt.Printf("city: %s\n", city.City)
  17. fmt.Printf("latitude: %f\n", latitude.Latitude)
  18. fmt.Printf("longitude: %f\n", longitude.Longitude)
  19. ip2location.Close()
  20. }


输出如下:

  1. country: United States of America
  2. region: California
  3. city: Mountain View
  4. latitude: 37.405991
  5. longitude: -122.078514

2. 全量数据获取函数
在项目中,需要从ip中获取国家、地区、经纬度等信息时候,直接调用对应函数,可以获取相应数值。

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/ip2location/ip2location-go"
  5. )
  6. func main() {
  7. ip := "8.8.8.8"
  8. ip2location.Open("./IP2LOCATION-LITE-DB5.BIN")
  9. results := ip2location.Get_all(ip)
  10. fmt.Printf("country_short: %s\n", results.Country_short)
  11. fmt.Printf("country_long: %s\n", results.Country_long)
  12. fmt.Printf("region: %s\n", results.Region)
  13. fmt.Printf("city: %s\n", results.City)
  14. fmt.Printf("isp: %s\n", results.Isp)
  15. fmt.Printf("latitude: %f\n", results.Latitude)
  16. fmt.Printf("longitude: %f\n", results.Longitude)
  17. fmt.Printf("domain: %s\n", results.Domain)
  18. fmt.Printf("zipcode: %s\n", results.Zipcode)
  19. fmt.Printf("timezone: %s\n", results.Timezone)
  20. fmt.Printf("netspeed: %s\n", results.Netspeed)
  21. fmt.Printf("iddcode: %s\n", results.Iddcode)
  22. fmt.Printf("areacode: %s\n", results.Areacode)
  23. fmt.Printf("weatherstationcode: %s\n", results.Weatherstationcode)
  24. fmt.Printf("weatherstationname: %s\n", results.Weatherstationname)
  25. fmt.Printf("mcc: %s\n", results.Mcc)
  26. fmt.Printf("mnc: %s\n", results.Mnc)
  27. fmt.Printf("mobilebrand: %s\n", results.Mobilebrand)
  28. fmt.Printf("elevation: %f\n", results.Elevation)
  29. fmt.Printf("usagetype: %s\n", results.Usagetype)
  30. fmt.Printf("api version: %s\n", ip2location.Api_version())
  31. ip2location.Close()
  32. }

3. 一些说明

  • 如果仅需要查询IPv4地址,请使用IPv4 BIN文件。
  • 如果同时需要查询IPv4地址和IPv6地址,请使用IPv6 BIN文件。

总结

ip2location库的使用非常简单,直接加载文件数据库,调用相关函数即可。目前很多国家都推行GDPR政策,网站不允许记录ip等隐私信息,那么ip2location库就有了巨大的使用空间。

参考资料

github.com/ip2location/ip2location-go
IP2Location.com