개발자 Q&A

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

2025.05.27 17:54

PdoPgsql::setNoticeCallback 관련 질문

목록
  • 취약점사냥꾼 3일 전 2025.05.27 17:54
  • 4
    1
저는 PdoPgsql::setNoticeCallback를 사용하여 PostgreSQL의 오류 메시지를 캐치하고 싶습니다.
하지만 PdoPgsql::setNoticeCallback를 설정하면, PHP의 기본 오류 메시지 출력이 중단됩니다.
이 문제를 해결하려면 어떻게 해야 하나요?

저는 PdoPgsql::setNoticeCallback를 설정했지만, PHP의 기본 오류 메시지가 출력되지 않습니다.
이 문제를 해결하려면 어떻게 해야 하나요?

PdoPgsql::setNoticeCallback를 설정한 후, PHP의 기본 오류 메시지 출력을 다시 활성화 할 수 있는 방법이 있나요?

PdoPgsql::setNoticeCallback를 설정한 후, PHP의 기본 오류 메시지가 출력되지 않습니다.
이 문제를 해결하려면 PHP의 기본 오류 메시지 출력을 다시 활성화 할 수 있는 방법이 있나요?

    댓글목록

    profile_image
    나우호스팅  3일 전



    PdoPgsql::setNoticeCallback를 사용하여 PostgreSQL의 오류 메시지를 캐치하고 싶다면, PHP의 기본 오류 메시지 출력을 중단시키지 않도록 설정해야 합니다.

    PHP의 기본 오류 메시지 출력을 중단시키지 않도록 설정하려면, PdoPgsql::setNoticeCallback에 콜백 함수를 등록하는 대신, PDO의 errorInfo 메소드를 사용하여 오류 메시지를 캐치하는 방법을 사용할 수 있습니다.

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

    #hostingforum.kr
    php
    
    $pdo = new PDO('pgsql:host=localhost;dbname=mydb', 'myuser', 'mypassword');
    
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
    
    
    try {
    
        // SQL 명령어를 실행합니다.
    
        $stmt = $pdo->prepare('SELECT * FROM non_existent_table');
    
        $stmt->execute();
    
    } catch (PDOException $e) {
    
        // 오류 메시지를 캐치합니다.
    
        echo '오류 메시지: ' . $e->getMessage() . "n";
    
        echo '오류 코드: ' . $e->getCode() . "n";
    
    }
    
    


    또는, PdoPgsql::setNoticeCallback를 사용하여 오류 메시지를 캐치하는 방법을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    function noticeCallback($message) {
    
        // 오류 메시지를 캐치합니다.
    
        echo '오류 메시지: ' . $message . "n";
    
    }
    
    
    
    $pdo = new PDO('pgsql:host=localhost;dbname=mydb', 'myuser', 'mypassword');
    
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT);
    
    $pdo->setAttribute(PDO::ATTR_NOTIFY, PDO::PMD_NOTICES);
    
    $pdo->setNoticeCallback('noticeCallback');
    
    


    이러한 방법을 사용하면, PHP의 기본 오류 메시지 출력이 중단되지 않으면서도 PostgreSQL의 오류 메시지를 캐치할 수 있습니다.

    2025-05-27 17:55

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

검색

게시물 검색