๊ด€๋ฆฌ ๋ฉ”๋‰ด

C-log

๐Ÿ˜์›น์‚ฌ์ดํŠธ์˜ ๋น„ํ•˜์ธ๋“œ PHP : ๋ณด์•ˆ XSS ๋ณธ๋ฌธ

DB/๐Ÿ˜PHP

๐Ÿ˜์›น์‚ฌ์ดํŠธ์˜ ๋น„ํ•˜์ธ๋“œ PHP : ๋ณด์•ˆ XSS

4:Bee 2023. 9. 9. 12:43
728x90

๋งˆ์ง€๋ง‰์œผ๋กœ ์šฐ๋ฆฌ๊ฐ€ textarea์—์„œ ๊ธ€์„ ์ž‘์„ฑํ•  ๋•Œ ๋ฐœ์ƒ๋˜๋Š” ๋ณด์•ˆ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•  ๊ฒƒ์ด๋‹ค. textarea์— ์šฐ๋ฆฌ๊ฐ€ ์ง์ ‘์ ์œผ๋กœ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑํ•˜๋ฉด ๊ทธ ์ฝ”๋“œ๊ฐ€ ์ ์šฉ๋˜๋Š” ๊ฒƒ์„ ๋ณผ ์ˆ˜ ์žˆ๋‹ค. ์ด๋Ÿฌํ•œ ํ˜„์ƒ์„ ๋ง‰๊ธฐ์œ„ํ•ด์„œ  htmlspecialchars()ํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•  ๊ฒƒ์ด๋‹ค. ์‚ฌ์šฉ์ž๊ฐ€ ์ž…๋ ฅํ•˜๋Š” ์ •๋ณด๋Š” ๋ชจ๋‘ ์˜์‹ฌํ•ด์•ผํ•œ๋‹ค. ๋”ฐ๋ผ์„œ ์•„๋ž˜ ์ฝ”๋“œ๋ฅผ ํ†ตํ•ด์„œ ์ „์— ์ž‘์„ฑํ•œ ์ฝ”๋“œ๋“ค์„ ๋น„๊ตํ•ด๋ณด์ž.

print.php

<?php
function print_title()
{
  if (isset($_GET['id'])) {
    echo htmlspecialchars($_GET['id']);
  } else {
    echo "Welcome";
  }
}

function print_description()
{
  if (isset($_GET['id']) && !$_GET['id'] == '') {
    echo htmlspecialchars(file_get_contents("data/" . $_GET['id']));
  } else if (isset($_GET['id']) && $_GET['id'] == '') {
    echo "Empty description. Retry!";
  } else {
    echo "Hello, PHP";
  }
}

function print_list()
{
  $list = scandir('data'); // ํ•ด๋‹น ๋””๋ ‰ํ† ๋ฆฌ ์•ˆ์— ์žˆ๋Š” ํŒŒ์ผ์„ list๋ผ๋Š” ๋ณ€์ˆ˜ ์•ˆ์— ๋‹ด์•„ ๋‘”๋‹ค.
  $i = 0;


  while ($i < count($list)) {
    $title = htmlspecialchars($list[$i]);
    //count ํ•จ์ˆ˜๋ฅผ ํ†ตํ•ด์„œ ํ•ด๋‹น list์˜ leng๊ธธ์ด๋ฅผ
    if ($list[$i] != '.') {
      if ($list[$i] != '..') {
?>
        <li><a href="index.php?id=<?= $title ?>"><?= $title ?></a></li>
<?php
      }
    }
    $i = $i + 1;
  }
}

?>

์‚ฌ์šฉ์ž๊ฐ€ ์ง์ ‘ ์ž…๋ ฅํ•˜๋Š” ๋ถ€๋ถ„์€ ๋ฌด์กฐ๊ฑด ๋ถˆ์‹ ํ•˜๊ณ  htmlspecialchars()ํ•จ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•ด์•ผํ•œ๋‹ค. ๋ณด์•ˆ๊ณผ ๊ด€๋ จ๋œ ์ •๋ณด๋Š” ์ดํ›„์— ์ฐจ์ฐจ ๋ณด์•ˆ์„ ๊ณต๋ถ€ํ•˜๋ฉด์„œ ๋” ๊นŠ์ด ์žˆ๊ฒŒ ๋‹ค๋ฃจ์–ด๋ณด๋ฉด ์ข‹๊ฒ ๋‹ค.

728x90
Comments