带数据库的国家的IP地址

我已经下载了ip-to-country.csv,它具有映射到国家/地区的ip范围。 我应该如何将这些数据存储到数据库中,如何查询IP地址在哪个范围内知道IP地址的来源?

我写了一个名为ip2c的小lib来做到这一点。 它使用来自webhosting.info的数据库,但也支持来自Software77的数据库。

它将CSV信息转换为紧凑的二进制格式,并且可以直接在文件,内存或内存映射文件中进行搜索。

Java API用法与此类似:

String ip = 85.64.225.159; int caching1 = IP2Country.NO_CACHE; // Straight on file, Fastest startup, slowest queries int caching2 = IP2Country.MEMORY_MAPPED; // Memory mapped file, fast startup, fast queries. int caching3 = IP2Country.MEMORY_CACHE; // load file into memory, slowerst startup, fastest queries IP2Country ip2c = new IP2Country(caching1); Country c = ip2c.getCountry(ip); if (c == null) { System.out.println("UNKNOWN"); } else { // will output IL ISR ISRAEL System.out.println(c.get2cStr() + " " + c.get3cStr() + " " + c.getName()); } 

查看IP到国家手册
ip-to-country.csv文件包含五个字段:

 * Begining of IP address range * Ending of IP address range * Two-character country code based on ISO 3166 * Three-character country code based on ISO 3166 * Country name based on ISO 3166 

您可以通过创建包含以下字段的表将此数据导入任何数据库:

 FIELD DATA TYPE FIELD DESCRIPTION IP_FROM NUMERICAL (DOUBLE) Beginning of IP address range. IP_TO NUMERICAL (DOUBLE) Ending of IP address range. COUNTRY_CODE2 CHAR(2) Two-character country code based on ISO 3166. COUNTRY_CODE3 CHAR(3) Three-character country code based on ISO 3166. COUNTRY_NAME VARCHAR(50) Country name based on ISO 3166 

您可以在将数据导入其中后查询上表,通过发出以下Select语句来查找相应IP编号的国家/地区:

 SELECT COUNTRY_NAME FROM  WHERE IP_FROM <= IP Number and IP_TO >= IP Number 

其中给定ABCD IP的IP号由下式计算:

 IP Number = A x (256*256*256) + B x (256*256) + C x 256 + D 

对于IPv4,您可以使用以下格式存储:

  1. 将IP地址转换为整数。 所以127.0.0.1将成为2 147 483 649
  2. 将您的桌面存储为三个IPFrom IPTo国家/地区
  3. 为IpFrom和IpTo构建索引

当您需要查找IP地址时,请执行以下查询

 SELECT Country from GeoIP where IpFrom < $IP and $IP < $IpTo 

这将为您提供IP地址的国家/地区

您只能为范围的ipTo(高边界)值构建索引并使用查询:

  select country from geoip where $ip <= ipTo limit 1 

(假设范围不像MaxMind数据库那样重叠)