개발자 Q&A

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

2025.03.22 21:53

session_set_save_handler에 관한 질문

목록
  • MySQL도깨비 1일 전 2025.03.22 21:53
  • 4
    1
선생님, session_set_save_handler 함수를 사용하여 세션을 저장하는 방법에 대해 조언을 부탁드립니다.

session_set_save_handler 함수를 사용하면 세션을 파일로 저장하거나 DB에 저장할 수 있습니다. 하지만 이 함수를 사용했을 때, 세션을 저장하는 방식에 대한 구체적인 예를 알려주시면 감사하겠습니다.

세션을 저장하는 방식은 다음과 같습니다.

1. 세션 데이터를 생성합니다.
2. 세션 데이터를 저장할 위치를 결정합니다. (파일, DB 등)
3. 세션 데이터를 저장합니다.
4. 세션 데이터를 불러옵니다.

이러한 과정을 수행하는 코드를 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    세션을 저장하는 방식은 다음과 같습니다.

    1. 세션 데이터를 생성합니다. 예를 들어, 사용자 아이디, 이름, 로그인 시간 등이 포함됩니다.
    2. 세션 데이터를 저장할 위치를 결정합니다. 예를 들어, 파일이나 DB를 사용할 수 있습니다.
    3. 세션 데이터를 저장합니다. 예를 들어, 파일에 데이터를 기록하거나 DB에 INSERT 문을 실행합니다.
    4. 세션 데이터를 불러옵니다. 예를 들어, 파일에서 데이터를 읽거나 DB에서 SELECT 문을 실행합니다.

    세션을 저장하는 코드 예제는 다음과 같습니다.

    파일 저장 예제

    #hostingforum.kr
    php
    
    function session_open($save_path, $session_name) {
    
        return true;
    
    }
    
    
    
    function session_close() {
    
        return true;
    
    }
    
    
    
    function session_read($session_id) {
    
        $data = file_get_contents($session_id);
    
        return $data;
    
    }
    
    
    
    function session_write($session_id, $data) {
    
        file_put_contents($session_id, $data);
    
        return true;
    
    }
    
    
    
    function session_destroy($session_id) {
    
        unlink($session_id);
    
        return true;
    
    }
    
    
    
    function session_gc($maxlifetime) {
    
        $files = glob('sessions/*');
    
        foreach ($files as $file) {
    
            if (filemtime($file) + $maxlifetime < time()) {
    
                unlink($file);
    
            }
    
        }
    
        return true;
    
    }
    
    
    
    session_set_save_handler(
    
        'session_open',
    
        'session_close',
    
        'session_read',
    
        'session_write',
    
        'session_destroy',
    
        'session_gc'
    
    );
    
    


    DB 저장 예제
    #hostingforum.kr
    php
    
    function session_open($save_path, $session_name) {
    
        return true;
    
    }
    
    
    
    function session_close() {
    
        return true;
    
    }
    
    
    
    function session_read($session_id) {
    
        $db = new PDO('sqlite:session.db');
    
        $stmt = $db->prepare('SELECT data FROM sessions WHERE id = :id');
    
        $stmt->bindParam(':id', $session_id);
    
        $stmt->execute();
    
        $data = $stmt->fetchColumn();
    
        return $data;
    
    }
    
    
    
    function session_write($session_id, $data) {
    
        $db = new PDO('sqlite:session.db');
    
        $stmt = $db->prepare('INSERT INTO sessions (id, data) VALUES (:id, :data)');
    
        $stmt->bindParam(':id', $session_id);
    
        $stmt->bindParam(':data', $data);
    
        $stmt->execute();
    
        return true;
    
    }
    
    
    
    function session_destroy($session_id) {
    
        $db = new PDO('sqlite:session.db');
    
        $stmt = $db->prepare('DELETE FROM sessions WHERE id = :id');
    
        $stmt->bindParam(':id', $session_id);
    
        $stmt->execute();
    
        return true;
    
    }
    
    
    
    function session_gc($maxlifetime) {
    
        $db = new PDO('sqlite:session.db');
    
        $stmt = $db->prepare('DELETE FROM sessions WHERE id = :id AND data IS NULL');
    
        $stmt->bindParam(':id', $session_id);
    
        $stmt->execute();
    
        return true;
    
    }
    
    
    
    session_set_save_handler(
    
        'session_open',
    
        'session_close',
    
        'session_read',
    
        'session_write',
    
        'session_destroy',
    
        'session_gc'
    
    );
    
    

    이러한 코드를 사용하여 세션을 저장하고 불러올 수 있습니다.

    2025-03-22 21:54

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

검색

게시물 검색