質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.02%
IPv6

IPv6は、インターネットプロトコルの一つ。主流となっているIPv4に変わるものとして設計されました。IPアドレスの需要の増大を予見して開発されたもので、従来よりも多くのIPアドレスの作成が可能です。

IPv4

IPv4(Internet Protocol version 4)は、インターネットプロトコルの一つ。インターネットに繋がったコンピューターや機器を識別するためのIPアドレスを32ビット表記で表わします。しかしIPv4は、限界があるため、IPv6が次世代プロトコルとして注目されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

受付中

phpとMySQLでIPアドレスを保存する方法

nikuatsu
nikuatsu

総合スコア174

IPv6

IPv6は、インターネットプロトコルの一つ。主流となっているIPv4に変わるものとして設計されました。IPアドレスの需要の増大を予見して開発されたもので、従来よりも多くのIPアドレスの作成が可能です。

IPv4

IPv4(Internet Protocol version 4)は、インターネットプロトコルの一つ。インターネットに繋がったコンピューターや機器を識別するためのIPアドレスを32ビット表記で表わします。しかしIPv4は、限界があるため、IPv6が次世代プロトコルとして注目されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

2回答

0グッド

3クリップ

494閲覧

投稿2022/09/07 16:47

前提

phpとMySQLを使い、「IPアドレスごとの操作履歴」の保存に取り組んでいます。

例えば「どのユーザーがいついいねを押したか」などです。
(非会員でもいいねが可能なのでIPアドレスでの実装を考えました。)

※以下、クエリ生成に変数の直渡しをしておりますが、質問用の簡易コードとしてご理解ください。

実現したいこと

IPアドレスをMySQLに保存する際の適切な処理を知りたいです。

発生している問題

特にカラムとしてVARCHARINTか決めかねています。

現状の保存処理

現状はphpの$_SERVERから得た値をVARCHAR(15)で、次のように保存しています。

SQL

1-- ipアドレスのテーブル 2CREATE TABLE tbl_ips ( `ip` VARCHAR(15) NOT NULL );

php

1$ip = $_SERVER["REMOTE_ADDR"]; 2$sql = "INSERT INTO tbl_ips ( ip ) VALUES ( $ip );"

調べたこと

調べたこと1:INET_ATONが便利っぽい

検索するうちにINET_ATONの存在を知りました。次のように使うようです。

SQL

1-- ipアドレスのテーブル 2CREATE TABLE tbl_ips ( `ip` INT(10) NOT NULL );

php

1$ip = $_SERVER["REMOTE_ADDR"]; 2$sql = "INSERT INTO tbl_ips ( ip ) VALUES ( INET_ATON( $ip ) );"

どうやらこれを使い数値で管理すると、次のように速度面と安全面のメリットがあると知りました。

>検索速度とか考えると今回の方法を使っていくべき
https://taitan916.info/blog/archives/2549

>パソコンからの成りすましをある程度抑制できます
https://ir.hatakenet.com/archives/91

調べたこと2:INET_ATONだけではダメっぽい

しかしさらに調べると、IPアドレスには ipv4 と ipv6 という種類があるようで、INET_ATONも ipv6 の場合はINET6_ATONを使わなければならないという次の記事を見つけました。

>IPv6の場合は、データ型にVARCHAR(16)を指定して、INET6_ATON()とINET6_NTOA()関数を使うようです
http://ajiblog.sblo.jp/article/104930826.html

生じた疑問

そこで疑問なのですが、INET_ATONINET6_ATONの区別が必要というこは、まずphpの段階で次の区別が必要ということになるかと思います。

php

1// ipv4 を判定 2function isIPv4($ip) { 3 return filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4); 4} 5 6// ipv6 を判定 7function isIPv6($ip) { 8 return filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6); 9}

そしてこう区別して、さらにテーブルも次のように区別するということになるのでしょうか?

SQL

1-- ipv4 のテーブル 2CREATE TABLE tbl_ipv4s ( `ipv4` INT(10) NOT NULL ); 3 4-- ipv6 のテーブル 5CREATE TABLE tbl_ipv6s ( `ipv6` VARCHAR(16) NOT NULL );

ずいぶん遠回りというか不自然な印象を覚えます。
いったいIPアドレスの管理するテーブル構造とは、どのようなものがよろしいでしょうか?

バージョン

PHP 8.0
MySQL 5.7.31
phpMyAdmin 4.4.15.10

宜しくお願いいたします。

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

m.ts10806

2022/09/07 23:07

>いったいIPアドレスの管理するテーブル構造とは、どのようなものがよろしいでしょうか? 結局どうしたいか 仕様です。決めてください。

回答2

0

IPv4か、IPv6はアドレス表記がそもそも違うので、それを判定すればいいのでは?
https://www.nic.ad.jp/ja/basics/terms/ipv6-text-representation.html

テーブルについて仕様ですし、アドレス格納用のエリアとIPv4か、IPv6を区別するエリアがあればいいように思いますが、お好みかと

投稿2022/09/09 08:00

okakemetal

総合スコア256

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

nikuatsu

2022/09/10 14:12

恐れ入りますが具体的なところを以下2つお伺いしたく思います。 > それを判定すればいいのでは? その判定は質問にある isIPv4(), isIPv6() で足りると思っているのですが、他のおすすめの方法があるのでしょうか? > IPv4か、IPv6を区別するエリアがあればいいように思います 次のように CREATE し、上記の判定をしてから `ipv` カラムを分ける。ということでしょうか? -- ipアドレスのテーブル CREATE TABLE tbl_ips ( `ipv` TINYINT(1) NOT NULL, `ip` INT(10) NOT NULL );

0

単に、IPv4、IPv6を問わず、文字列で入れておけばいいだけのような気もします。

検索速度とか考えると今回の方法を使っていくべき

ユーザー追跡用途であれば、完全一致の検索さえできればいいので、文字列でインデックスを貼れば全く問題ありません。

パソコンからの成りすましをある程度抑制できます

これは(すでに廃れてしまった)端末識別情報との比較で、IPアドレスをどう保管するかとは無関係です。

投稿2022/09/07 23:21

maisumakun

総合スコア141508

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

nikuatsu

2022/09/10 14:06

すると、「ユーザー追跡用途であれば、 INET_ATON や INET6_ATON は現代では意義がない」と考えてよさそうでしょうか? そして、「ユーザー追跡用途でなければ、どう使うのか?」と言う点をもうすこしお伺いできましたら幸いです。
maisumakun

2022/09/10 22:03

> すると、「ユーザー追跡用途であれば、 INET_ATON や INET6_ATON は現代では意義がない」と考えてよさそうでしょうか? 物事の捉え方がおかしな印象を受けます。 INET_ATON や INET6_ATON は単にデータを変換する関数なので、「そのデータ変換が必要なら使う」というだけの話です。現代とか、そういうのは無関係です。
maisumakun

2022/09/10 22:04

> そして、「ユーザー追跡用途でなければ、どう使うのか?」と言う点をもうすこしお伺いできましたら幸いです。 荒らし対策などで特定の範囲のIPアドレスを抽出する必要がある、ようなパターンはありえます。

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.02%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

IPv6

IPv6は、インターネットプロトコルの一つ。主流となっているIPv4に変わるものとして設計されました。IPアドレスの需要の増大を予見して開発されたもので、従来よりも多くのIPアドレスの作成が可能です。

IPv4

IPv4(Internet Protocol version 4)は、インターネットプロトコルの一つ。インターネットに繋がったコンピューターや機器を識別するためのIPアドレスを32ビット表記で表わします。しかしIPv4は、限界があるため、IPv6が次世代プロトコルとして注目されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。