PHP中如何將ip地址轉成十進位數_PHP教程

來源:互聯網
上載者:User
  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

http://www.bkjia.com/PHPjc/371387.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/371387.htmlTechArticlePHP 中如何將ip地址轉成十進位數呢?現在PHP中有很多時候都會用到ip地址,但是這個ip地址擷取的時候都不是10進位的。那麼PHP中如何將ip地址...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.