どこから来ているか、IPからわかる無料のデータベースと商用のデータベースがいくつかあります。
maxmind の無料データベース [*]: http://dev.maxmind.com/geoip/geolite
および 2 つのコマーシャル:
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 に感謝します。