개발자 Q&A

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

2025.06.09 20:54

mysqli::prepare 사용 시 오류 해결 방법을 알려주세요

목록
  • 스택오버플로우러버 3일 전 2025.06.09 20:54
  • 60
    1
저는 php에서 mysqli::prepare 함수를 사용하여 쿼리를 실행하려고 합니다.
하지만, 사용자가 입력한 데이터가 특정 문자를 포함할 때 오류가 발생합니다.
이러한 문제를 해결하기 위해 mysqli::prepare 함수의 옵션을 어떻게 설정해야 하는지 알려주세요.

예를 들어, 사용자가 입력한 데이터가 "Robert'); DROP TABLE Students;"와 같은 문자를 포함할 때 오류가 발생합니다.
이러한 문자를 필터링 하거나 방지하는 방법을 알려주세요.

또한, mysqli::prepare 함수를 사용하여 SQL 인젝션 공격을 방지하는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  3일 전



    mysqli::prepare 함수를 사용하여 SQL 인젝션 공격을 방지하는 방법은 다음과 같습니다.

    1. 데이터를 필터링 하기: 사용자가 입력한 데이터를 필터링하여 특정 문자를 제거하거나 변환하는 방법을 사용할 수 있습니다. 예를 들어, 사용자가 입력한 데이터를 HTML 엔티티로 변환하여 특정 문자를 방지할 수 있습니다.

    #hostingforum.kr
    php
    
    $data = htmlspecialchars($_POST['data']);
    
    


    2. 데이터를.escape 하기: 사용자가 입력한 데이터를 MySQL의 ESCAPE 함수를 사용하여 특정 문자를 방지할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM table WHERE column = ?");
    
    $stmt->bind_param("s", $mysqli->real_escape_string($data));
    
    


    3. prepared statement의 옵션 설정: prepared statement의 옵션을 설정하여 특정 문자를 방지할 수 있습니다. 예를 들어, `mysqli::prepare` 함수의 옵션 `MYSQLI_INIT_COMMAND`를 사용하여 SQL 인젝션 공격을 방지할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM table WHERE column = ?", MYSQLI_INIT_COMMAND);
    
    


    4. SQL 인젝션 공격을 방지하기: SQL 인젝션 공격을 방지하기 위해 prepared statement를 사용하는 것을 권장합니다. prepared statement를 사용하면 사용자가 입력한 데이터를 직접 SQL 쿼리에 삽입하는 것을 방지할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM table WHERE column = ?");
    
    $stmt->bind_param("s", $data);
    
    $stmt->execute();
    
    


    5. 데이터를 검증하기: 사용자가 입력한 데이터를 검증하여 특정 문자를 방지할 수 있습니다. 예를 들어, 사용자가 입력한 데이터를 정규표현식으로 검증할 수 있습니다.

    #hostingforum.kr
    php
    
    if (!preg_match("/^[a-zA-Z0-9]+$/", $data)) {
    
        // 데이터가 유효하지 않은 경우
    
    }
    
    


    위 방법을 사용하여 SQL 인젝션 공격을 방지하고, 사용자가 입력한 데이터를 필터링하거나 방지할 수 있습니다.

    2025-06-09 20:55

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

검색

게시물 검색