カテゴリ: PHP 更新日: 2026/01/16

PHPでユーザーごとにセッションを管理する方法!初心者にもわかるWebログインの仕組み

PHP でユーザーごとにセッションを管理する方法
PHP でユーザーごとにセッションを管理する方法

先生と生徒の会話形式で理解しよう

生徒

「PHPでログイン機能を作ったときに、ユーザーごとの情報を覚えておく方法ってありますか?」

先生

「はい、PHPでは“セッション”という仕組みを使って、ユーザーごとの情報を管理することができますよ。」

生徒

「セッションって何ですか?なんだか難しそう…」

先生

「心配しなくて大丈夫です。わかりやすく、例えを使って説明していきますね!」

1. セッションとは?PHPのログイン管理の基本用語

1. セッションとは?PHPのログイン管理の基本用語
1. セッションとは?PHPのログイン管理の基本用語

セッション(Session)とは、PHPでユーザーがWebサイトを利用している間に、その人が「誰なのか」「どんな操作をしたのか」といった情報を一時的に覚えておく仕組みです。

例えば、遊園地の入場券のようなものです。入場券を見せれば、スタッフは「この人はチケットを買った人だな」とわかりますよね。セッションはその「入場券」をWeb上で実現するような働きをします。

ログイン処理をすると、サーバーは「この人はログインしている人だ」と覚えておきます。ログイン後に別のページに移動しても、セッションがあることでログイン状態をキープできます。

2. PHPでセッションを使う基本の書き方

2. PHPでセッションを使う基本の書き方
2. PHPでセッションを使う基本の書き方

PHPでセッションを使うときは、まず最初にsession_start()という命令を書きます。これによって、PHPがセッションを開始し、ユーザーごとの情報を保存できるようになります。

使い方の基本は次のようになります。


<?php
session_start();
$_SESSION['user'] = 'taro';
?>

ここで$_SESSION['user']は、「セッションの中に"user"という名前で"taro"という情報を保存する」という意味です。

3. ログイン時にユーザー情報をセッションに保存しよう

3. ログイン時にユーザー情報をセッションに保存しよう
3. ログイン時にユーザー情報をセッションに保存しよう

次は、ユーザーがログインしたときに、セッションを使ってログイン状態を管理する例です。まずはログイン処理を書いてみましょう。


<?php
session_start();

$username = $_POST['username'];
$password = $_POST['password'];

// 仮のユーザー情報
if ($username === 'taro' && $password === 'pass123') {
    $_SESSION['user'] = $username;
    header('Location: mypage.php');
    exit;
} else {
    echo 'ログインに失敗しました。';
}
?>

このように、ログインに成功したら、セッションにユーザー名を保存して次のページへ移動します。

4. マイページでユーザーごとの情報を表示する

4. マイページでユーザーごとの情報を表示する
4. マイページでユーザーごとの情報を表示する

次はログイン後のページ、いわゆる「マイページ」でセッションを使ってログイン中のユーザーの名前を表示してみましょう。


<?php
session_start();
if (!isset($_SESSION['user'])) {
    header('Location: loginform.html');
    exit;
}
echo "ようこそ、" . $_SESSION['user'] . "さん!";
?>

issetは「この変数が存在しているか?」を調べる関数です。セッションにuserがあるかを確認し、なければログイン画面に戻します。

5. セッションを使ってユーザー情報を保持するとは?

5. セッションを使ってユーザー情報を保持するとは?
5. セッションを使ってユーザー情報を保持するとは?

セッションを使えば、ユーザーが別のページに移動しても、その間に「ログイン中かどうか」や「誰が操作しているか」を記録し続けることができます。

たとえば、買い物サイトで「カートに入れた商品」は、セッションを使って一時的に記録されます。ページを移動しても商品は消えませんよね。それと同じことがログイン状態にも当てはまります。

6. ログアウト処理でセッションを削除しよう

6. ログアウト処理でセッションを削除しよう
6. ログアウト処理でセッションを削除しよう

ログアウトするには、セッションを削除する必要があります。次のように書きます。


<?php
session_start();
session_unset();
session_destroy();
header('Location: loginform.html');
exit;
?>

session_unset()はセッションの中身を全部空にし、session_destroy()はセッション自体を破棄します。ログアウト後はログインページへ戻すのが一般的です。

7. 複数ユーザーを管理するにはどうする?

7. 複数ユーザーを管理するにはどうする?
7. 複数ユーザーを管理するにはどうする?

実際には、1人ではなく複数のユーザーが同時にWebサイトにアクセスします。でもセッションは「その人ごとに自動で別々に管理」されるので安心です。

たとえば、同じページをAさんとBさんが開いたとしても、それぞれのセッションはサーバー側で別々に処理され、$_SESSION['user']にAさんとBさんの名前がそれぞれ別に入ります。

8. セッションIDとは?安全性も意識しよう

8. セッションIDとは?安全性も意識しよう
8. セッションIDとは?安全性も意識しよう

セッションには、内部的に「セッションID(アイディー)」という一意の番号が使われています。これはユーザーごとに発行され、クッキーという仕組みを通じて自動的に管理されます。

セッションIDが漏れると、他人になりすまされるリスクがあるので、ログイン状態を守るためにはsession_regenerate_id()を使って、IDを再発行するのが安全です。


<?php
session_start();
session_regenerate_id(true);
?>

ログイン直後にこの関数を使うと、安全性が高まります。

コメント
コメント投稿は、ログインしてください

まだ口コミはありません。

カテゴリの一覧へ
新着記事
New1
Python
Pythonのカスタム例外を作成する方法を完全解説!初心者でもわかる独自のExceptionクラス入門
New2
PHP
PHP の型変換を完全ガイド!初心者でもわかる明示的変換・自動変換
New3
PHP
PHPの真偽値と条件判定をやさしく解説!初心者でもわかるempty・isset・is_nullの使い方
New4
PHP
PHP の file_get_contents() を使ってファイルを読み込む方法!初心者でもできる簡単なファイル操作
人気記事
No.1
Java&Spring記事人気No1
Python
Pythonのfinally文を徹底解説!例外発生時でも実行される処理の書き方と使い方
No.2
Java&Spring記事人気No2
Python
Pythonで辞書のネスト構造(入れ子辞書)を扱う方法 初心者向け完全ガイド
No.3
Java&Spring記事人気No3
Python
Pythonのクラスメソッドと静的メソッドの違いとは?初心者でも迷わない使い分けガイド
No.4
Java&Spring記事人気No4
Python
Pythonの書き方を基本から解説!はじめてのPythonプログラム
No.5
Java&Spring記事人気No5
Python
Pythonで文字列が数値か判定する方法!isdigit()・isnumeric()の違い
No.6
Java&Spring記事人気No6
Python
Pythonのコンストラクタ(__init__)の使い方!初心者でもわかるオブジェクトの初期化
No.7
Java&Spring記事人気No7
PHP
PHPの可変長引数(...$args)の使い方を完全ガイド!初心者でもわかる基本と活用方法
No.8
Java&Spring記事人気No8
PHP
初心者向けPHP の MySQL のデータを更新する方法(UPDATE 文)完全ガイド