gpt4 book ai didi

asp.net - 地理定位 IP 地址

转载 作者:行者123 更新时间:2023-12-01 10:03:25 24 4
gpt4 key购买 nike

我希望按大陆定位我的服务器请求。

基本上,在做了一些初步研究之后,似乎有 3 种方法:1) 使用浏览器提供的地理定位(但我认为当浏览器请求使用地理定位许可时,没有人认真地单击"is"); 2) 获取 IP 地址列表,将该列表放入服务器上的数据库中,然后每次收到请求时,从该数据库中读取;我不想在每次请求时都必须访问数据库。 3) 对外部服务器进行 HTTP 调用以获取位置;甚至可能比 2 慢)。

基本上,我不太关心用户的确切位置,我只需要知道他们在哪个大陆:北美、欧洲...

有没有一种不需要任何用户交互并且不需要在每次请求时都读取数据库的方法来做到这一点?当我访问 www.intel.com 时,我会自动重新路由到法语站点;他们是怎么做到的?

感谢您的建议。

最佳答案

有一些免费的和一些商业的数据库可以告诉你从 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

最好将结果缓存在 session 变量上,而不是在每个页面请求上一次又一次地搜索。

[*] 非常感谢 maxmind 仍然将免费数据库与商业广告一起发布。

关于asp.net - 地理定位 IP 地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13461803/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com