我已经下载了 ip-to-country.csv,其中包含映射到国家/地区的 ip 范围。我应该如何将这些数据存储到数据库中,以及如何查询 IP 地址的范围以了解 IP 地址的来源?
问问题
6658 次
4 回答
5
为此,我编写了一个名为ip2c的小库。它使用来自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());
}
于 2010-05-06T06:44:02.447 回答
3
查看IP-to-Country 手册
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 <TableName> 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
于 2010-05-06T06:25:35.173 回答
2
对于 IPv4,您可以按以下格式存储:
- 将 IP 地址转换为整数。所以 127.0.0.1 会变成 2 147 483 649
- 将您的表格存储为三重 IPFrom IPTo Country
- 为 IpFrom 和 IpTo 构建索引
当您需要查找 IP 地址时,请执行以下查询
SELECT Country from GeoIP where IpFrom < $IP and $IP < $IpTo
这将为您提供 IP 地址的国家/地区
于 2010-05-05T18:29:16.550 回答
1
您可以仅为范围的 ipTo(高边界)值构建索引并使用查询:
select country from geoip where $ip <= ipTo limit 1
(假设范围不像 MaxMind 数据库中那样重叠)
于 2010-05-05T19:13:19.157 回答