スポンサーリンク

MySQLにIPアドレスを保存する場合に、ドット区切り表記の文字列(192.168.0.1)を保存してもいいですが、これだとuint32_tに比べて容量が大きくなってしまいます。
そのためlong型で保存したほうが、検索する場合にも、DBの容量的にもお勧めです。

PHPの場合、ドット表記のIPアドレスをlong型に変換するには、ip2long()を利用します。
MySQLの場合、inet_aton()が用意されているので、$_SERVER['REMOTE_ADDR']をinet_aton()で変換してもいいです。
ip2longで変換して、INT UNSIGENDに格納すると 0 になってしまいます。
そのため、sprintfで一度変換する必要がでてきました。

テーブルの例
CREATE TABLE ipaddrs(
`ip` INT(2) UNSIGNED default 0
);

サンプルコード
<?php
$dotip = $_SERVER['REMOTE_ADDR'];
$longip = ip2long($dotip);
$ip = sprintf ("%u", $longip);
$sql =<<<SQL
INSERT INTO ipaddrs(ip) VALUES('$ip');
SQL;
?>

関連
[2008-05-31-1] PHP ドット表記のIPアドレスと整数を相互に変換する ip2long long2ip
[2008-05-30-2] PHP ドット表記のIPアドレスを整数に変換する
参照しているページ (サイト内): [2008-08-01-2] [2008-08-01-1] [2008-07-27-2] [2008-07-27-1]

スポンサーリンク
スポンサーリンク
 
いつもシェア、ありがとうございます!


もっと情報を探しませんか?

関連記事

最近の記事

人気のページ

スポンサーリンク
 

過去ログ

2020 : 01 02 03 04 05 06 07 08 09 10 11 12
2019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12

サイト

Vim入門

C言語入門

C++入門

JavaScript/Node.js入門

Python入門

FreeBSD入門

Ubuntu入門

セキュリティ入門

パソコン自作入門

ブログ

トップ


プライバシーポリシー