{category}

PHP - XSS対策

strip_tags()

ストリップタグズ(Web開発とセキュリティ

意味 HTMLタグを取り除く


strip_tags()とは?

strip_tags()は、文字列からHTMLタグとPHPタグを取り除く関数です。これにより、ユーザーが入力したHTMLやPHPコードを無効化し、XSS攻撃のリスクを軽減できます。ただし、完全な対策としては不十分な場合があるので注意が必要です。

strip_tags()の具体的な使い方

HTMLタグ除去の例

$userInput = '<p>これは<script>alert("危険!");</script>テストです。<a href="#">リンク</a></p>';
$cleanText = strip_tags($userInput, '<p><a>');

echo '清浄化されたテキスト: ' . $cleanText;

👇出力結果

清浄化されたテキスト: <p>これはテストです。<a href="#">リンク</a></p>

この例では、HTMLタグとJavaScriptコードを含む$userInputからHTMLタグを除去しています。strip_tags()関数の第二引数で'<p><a>'を指定することで、pタグとaタグのみを許可しています。結果として、scriptタグなどの潜在的に危険なタグが除去され、許可されたタグのみが残ります。これにより、XSS攻撃のリスクを軽減しつつ、一部の安全なHTML構造を保持できます。

strip_tags()に関するよくある質問

Q. strip_tags()の基本的な使い方は?
A. strip_tags()は、文字列からHTMLタグとPHPタグを取り除く関数です。基本的な使い方は strip_tags($string) で、$stringから全てのタグを除去します。特定のタグを許可したい場合は、第二引数にタグを指定できます。
Q. 許可するタグの指定方法は?
A. 許可するタグは、strip_tags()の第二引数で指定します。例えば、strip_tags($string, '<p><a>') とすると、pタグとaタグのみが許可されます。複数のタグを指定する場合は、角括弧で囲んで連続して記述します。
Q. strip_tags()はXSS対策として十分?
A. strip_tags()はXSS対策の一部として有効ですが、完全な対策としては不十分な場合があります。例えば、属性を通じた攻撃を防ぐことはできません。より完全な保護には、htmlspecialchars()との併用や、より高度なサニタイズライブラリの使用を検討すべきです。

PHPのstrip_tags()についても学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、PHPのstrip_tags()やトークン生成、setcookie()、password_hash()、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

よく使われる単語にだけ絞って学習することができるので、効率的にプログラミングが学習できます。

1日5分の暗記でプログラミンが身に付く!プログラミング単語帳 公式ストアで発売中!

HTML編、CSS編、JavaScript編、PHP編、Ruby編、その他単語編の6シリーズ分が公式ストアにて販売中です。気になった方はぜひ購入してみてください。


PHPを学べる「プログラミング単語帳」アプリ

プログラミング単語帳がアプリになりました!PHPはもちろん、10種類のプログラミング言語の中から、よく使われる単語をスマホで学習できます。

収録単語は2,000単語以上!
現在は、HTML、CSS、JavaScirpt、PHP、Laravel、Ruby、Python、MySQL、Linux、など10カテゴリーの単語帳が1つのアプリに収録されています。

いつでも、どこでも、隙間時間を有効活用して、プログラミングを効率的に学べるので、ぜひダウンロードしてみてください。

2024年7月アップデート情報:「Laravel」カテゴリーが追加されましました!

2024年8月アップデート情報:「MySQL」「Linux」カテゴリーが追加されましました!


関連するそのほかの単語

トークン生成

CSRF対策の一手法

種類: CSRF対策

setcookie()

クッキーを設定する関数

種類: クッキー

password_hash()

パスワードを安全に保存

種類: パスワードハッシュ

モック

テスト用の模擬オブジェクト

種類: ユニットテスト

foreach

配列の要素を順に処理

種類: ループ