有一些免费的和一些商业的数据库,可以告诉你从 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,然后使用函数将其转换为 long,然后搜索数据库,这个 long 数字在哪里适合。
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 仍然与商业广告一起发布免费数据库。