PHPセキュリティ サーバ変数
スポンサーリンク
PHPで、サーバ変数 $_SERVERのPHP_SELFを利用して、リンクを作るということはよくやると思います。
たとえば、こんな感じです。
[2008-01-31-1] で PHP_SELFと SCRIPT_NAME を比較しましたが、PHP_SELFを参照した場合、PHPのスクリプトファイルの後ろに続く文字列もPHPに渡ってしまいます。
これを何も考えずに、表示してしまうとセキュリティ上の問題が発生します。
どんな問題が発生するかというと、XSS(クロスサイトスクリプティング)です。
http://foo.bar.orz/dev/php/SCRIPT_NAME.php/%22%3E%3Cscript%3Ealert(0);%3C/script%3E
は、
http://foo.bar.orz/dev/php/SCRIPT_NAME.php/"><script>alert(0);</script>
の意味です。
$_SERVER['PHP_SELF']をechoで表示してしまうと
PHPのfilterモジュールでサニタイズしてみると
は
たとえば、こんな感じです。
<a href="<?php echo $_SERVER['PHP_SELF']; ?>">hoge</a>
[2008-01-31-1] で PHP_SELFと SCRIPT_NAME を比較しましたが、PHP_SELFを参照した場合、PHPのスクリプトファイルの後ろに続く文字列もPHPに渡ってしまいます。
これを何も考えずに、表示してしまうとセキュリティ上の問題が発生します。
どんな問題が発生するかというと、XSS(クロスサイトスクリプティング)です。
http://foo.bar.orz/dev/php/SCRIPT_NAME.php/%22%3E%3Cscript%3Ealert(0);%3C/script%3E
は、
http://foo.bar.orz/dev/php/SCRIPT_NAME.php/"><script>alert(0);</script>
の意味です。
$_SERVER['PHP_SELF']をechoで表示してしまうと
<a href="/dev/php/SCRIPT_NAME.php/"><script>alert(0);</script>">hoge</a>となって、JavaScriptが実行することができます。
PHPのfilterモジュールでサニタイズしてみると
<a href="<?php echo(filter_input(INPUT_SERVER, 'PHP_SELF', FILTER_SANITIZE_STRIPPED)); ?>">hoge</a> ?>
は
<a href="/dev/php/SCRIPT_NAME.php/"alert(0);">hoge</a>
となるわけです。
しかしながら PHP_SELF じゃなくて SCRIPT_NAME を使えば安心のように思えます。
というわけで、 PHP_SELF を撲滅したほうがいいかも、です。
findコマンドとgrepコマンドで、PHP_SELFを簡単に見つけられます。
find . -name "*.php" -exec fgrep PHP_SELF {} \; find . -name "*.inc" -exec fgrep PHP_SELF {} \;
参照しているページ (サイト内): [2013-02-06-1]
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12