PHP 中如何將ip地址轉成十進位數呢?現在PHP中有很多時候都會用到ip地址,但是這個ip地址擷取的時候都不是10進位的。那麼PHP中如何將ip地址轉成十進位數就是我們比較頭疼的事情了,下面兩種方法是我整理處理來相對比較簡單的IP地址轉成十進位數的方法。希望能對大家有所協助。
方法一:
| 代碼如下 |
複製代碼 |
public function ipToLong(){ $ip = $_SERVER['REMOTE_ADDR']; $ip = explode('.', $ip); $ip = array_reverse($ip);//數組反轉 $r = 0; for($i=0,$j=count($ip); $i<$j; $i++){ $r += $ip[$i] * pow(256, $i); } $r = sprintf("%u", $r); echo $r; } |
方法二:
| 代碼如下 |
複製代碼 |
public function ipToLong(){ $ip = $_SERVER['REMOTE_ADDR']; $ip = explode('.',$ip); $r = ($ip[0] << 24) | ($ip[1] << 16) | ($ip[2] << 8) | $ip[3]; if($r < 0) $r += 4294967296; echo $r ; } |
兩個結果在本機伺服器中的結果都是3232235877,運用的ip是192.168.1.101。我們用ping 192.168.1.101 和 ping 3232235877來進行檢測,看是否一樣。
可能有些朋友不知道mysql與php中都提供了IP轉換十進位數函數
MySQL 提供了INET_ATON 和 INET_NTOA 兩個函數來進行地址和整數之間的轉換。
1. IP 由點分格式,轉換為數字格式。
| 代碼如下 |
複製代碼 |
mysql> select inet_aton('127.0.0.1'); +------------------------+ | inet_aton('127.0.0.1') | +------------------------+ | 2130706433 | +------------------------+ 1 row in set (0.00 sec) |
2. IP 由數字格式轉換為點分格式。
| 代碼如下 |
複製代碼 |
mysql> select inet_ntoa(2130706433); +-----------------------+ | inet_ntoa(2130706433) | +-----------------------+ | 127.0.0.1 | +-----------------------+ 1 row in set (0.00 sec) |
php可直接使用ip2long函數
| 代碼如下 |
複製代碼 |
echo ip2long('192.168.1.38'); 輸出:3232235814
|