개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.16 20:38

session_destroy() 함수에 대한 질문

목록
  • 개발하는곰돌이 6일 전 2025.04.16 20:38
  • 10
    1
안녕하세요 선생님,
session_destroy() 함수를 사용하여 세션을 삭제할 때, 다른 페이지로 redirect 하기 전에 session_destroy() 함수를 사용해야 하는지 궁금합니다.
다음과 같이 코드를 작성했습니다.

php

<?php

session_start();

// 데이터 삭제

unset($_SESSION['id']);

unset($_SESSION['pw']);



// 세션 삭제

session_destroy();



// redirect

header('Location: login.php');

exit;

?>



이 코드는 세션을 삭제하고 login.php로 redirect 하기 전에 문제가 없는지 궁금합니다.
다른 방법이 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  6일 전



    session_destroy() 함수를 사용하여 세션을 삭제할 때, 다른 페이지로 redirect 하기 전에 session_destroy() 함수를 사용할 필요는 없습니다.

    이유는 session_destroy() 함수는 세션을 삭제하는 함수이기 때문입니다. 세션을 삭제한 후 redirect를 하게 되면, 이전에 삭제한 세션을 다시 사용할 수 있습니다.

    따라서, 세션을 삭제한 후 redirect를 하기 전에 session_destroy() 함수를 사용할 필요는 없습니다.

    다음과 같이 코드를 작성할 수 있습니다.

    php
    
    <?php
    
    session_start();
    
    // 데이터 삭제
    
    unset($_SESSION['id']);
    
    unset($_SESSION['pw']);
    
    
    
    // redirect
    
    header('Location: login.php');
    
    exit;
    
    ?>
    
    


    만약, 다른 방법이 필요한 경우에는 세션을 삭제한 후 세션을 다시 시작하지 않도록 하거나, 세션을 삭제한 후 redirect를 하기 전에 세션을 다시 시작하도록 할 수 있습니다.

    예를 들어, 다음과 같이 코드를 작성할 수 있습니다.

    php
    
    <?php
    
    session_start();
    
    // 데이터 삭제
    
    unset($_SESSION['id']);
    
    unset($_SESSION['pw']);
    
    
    
    // 세션 삭제
    
    session_destroy();
    
    
    
    // redirect
    
    header('Location: login.php');
    
    exit;
    
    ?>
    
    


    이 경우, 세션을 삭제한 후 세션을 다시 시작하지 않도록 하므로, 이전에 삭제한 세션을 다시 사용할 수 없습니다.

    2025-04-16 20:39

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 13,578건 / 102 페이지

검색

게시물 검색