有一些免费和商业数据库可以根据IP地址告诉你它来自哪里。
免费的数据库来自maxmind [*]: http://dev.maxmind.com/geoip/geolite
还有两个商业数据库:
http://www.ip2location.com
http://www.maxmind.com
在这个网站上,你也可以找到asp.net的示例,了解如何使用这些数据。此外,他们还提供其他免费服务,可以查看用户来自哪里。
从这里获取API示例和数据库:http://www.maxmind.com/download/geoip/
如果只需要国家,则可以使用此数据库文件。
http://www.maxmind.com/download/geoip/database/GeoIPCountryCSV.zip
这段文字只包含国家信息,并且与其余内容相比较小。
简单来说,数据库的格式如下:
"1.20.0.0","1.20.255.255","18087936","18153471","TH","Thailand"
"1.21.0.0","1.21.255.255","18153472","18219007","JP","Japan"
"1.22.0.0","1.23.255.255","18219008","18350079","IN","India"
"1.24.0.0","1.31.255.255","18350080","18874367","CN","China"
长数字是 IP 的翻译。因此,您可以读取用户的 IP,然后使用函数将其转换为长数字,然后搜索数据库,找到与该长数字匹配的记录。
public long addrToNum(IPAddress Address)
{
byte[] b = BitConverter.GetBytes(Address.Address);
if (b.Length == 8)
return (long)(((long)16777216 * b[0]) + ((long)(65536 * b[1])) + ((long)(256 * b[2])) + b[3]);
else
return 0;
}
如果您将它们添加到数据库中,则可以在这些长数字上对数据库进行索引,并查找 IP 所在的位置,如下所示:
Select TOP 1 * from GeoIPCountryWhois WITH (NOLOCK) Where @myIpToLong BETWEEN begin_num AND end_num
把结果缓存在会话变量中,而不是在每个页面请求中再次搜索,这样做很好。
[*] 非常感谢maxmind与商业数据库一起发布免费数据库。