3

このページにはこう書かれています

XSS 関連のhtmlspecialchars()攻撃を防ぐために SID を出力するときに使用できます。

を使用せずに SID を印刷すると、誰かがどのような攻撃を行う可能性がありますhtmlspecialchars()か?

セッション ID には、数字と文字のみを含めることができます。何か不足していますか?

4

1 に答える 1

6

セッション ID は通常、クライアント(Cookie やGETparams など) に保存されるため、スクリプトや URL を変更することで変更できます。

ここで、誰かがCookie を変更SIDし、JS コードを変更して、他の場所にリダイレクトすることができたと想像してください。その値をエスケープせずにページに出力すると、Cookie をクリアするか JavaScript を無効にしない限り、ユーザーは毎回リダイレクトされます。

つまり、セッション ID はクライアントから取得され、安全ではありません (一部の PHP フレームワークなどに含まれる Cookie 署名など、変更されていないことを保証する追加のメカニズムを使用しない限り)。危害を与える。

これは、SQL クエリを作成するときにこの値を安全なものとして使用してはならない理由と同じです (したがって、SID は SQL インジェクションが可能な場所でもあります)。

于 2012-09-06T02:03:52.490 に答える