redis技巧--IP地址查詢對應城市

場景:redis

根據IP地址判斷用戶所在地,雖然網上有好多篇了,但我記錄一個一看就懂的,不用看超長文字再本身理解了。spa

咱們有城市和IP地址段的對應關係,如:code

上海: 202.127.0.0 ~ 202.127.4.255blog

北京: 122.200.64.0 ~ 122.207.255.255ip

此時若是用戶的IP地址爲122.202.2.0,咱們就能根據這個表知道他的地址位於北京。ci

方法:it

使用有序集合記錄這個表,每一個城市存儲兩條數據,一條是城市名對應的分數爲最大IP地址。另外一條是「#」加上城市名對應的分數爲最小IP地址。class

分析:方法

取大於當前IP的最近的上一個分數值,若是值是#開頭,說明是某一個城市的最小IP,就是當前IP不在任何城市範圍內,若是不是#開頭,那IP就屬於這個城市。im

|----上海最大IP(80=>sh) |----上海最小IP(50=>#sh)
|----北京最大IP(30=>bj) |----北京最小IP(20=>#bj)

代碼實現:

//先用ip2long把IP地址轉爲對應的十進制數,這裏爲了方便直接使用虛擬數字表示
$redis->zAdd('zset', 20, '#bj'); //最小IP加#
$redis->zAdd('zset', 30, 'bj'); $redis->zAdd('zset', 50, '#sh'); //最小IP加#
$redis->zAdd('zset', 80, 'sh'); //獲取IP對應的城市
$cityIp = 34; $b = $redis->zRangeByScore('zset', $cityIp, '+inf', array( 'limit'=>array(0,1) )); if ($b) { if (strpos($b[0], '#') === 0) { echo '城市不在'; } else { echo '城市是',print_r($b); } } else { echo '城市不存在'; }
相關文章
相關標籤/搜索