程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP中如何將ip地址轉成十進制數

PHP中如何將ip地址轉成十進制數

編輯:關於PHP編程

       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

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved