개발자 Q&A

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

2025.03.04 10:01

mysqli::real_escape_string 함수 사용 방법에 대한 질문

  • Godot러버 12일 전 2025.03.04 10:01
  • 5
    1
저는 mysqli::real_escape_string 함수를 사용하여 데이터베이스에 INSERT 문을 수행할 때 SQL 인젝션 공격을 방지하고 싶습니다. 그러나 이 함수의 정확한 사용 방법에 대해 잘 이해하지 못하고 있습니다.

mysqli::real_escape_string 함수를 사용하여 데이터를.escape 하기 전에 어떤 처리를 해야 하나요? 예를 들어, 문자열을 escape 하기 전에 어떤 함수를 호출해야 하나요?

또한, 이 함수를 사용하여 데이터를 escape 한 후, INSERT 문에서 값을 대입할 때는 어떤 방법을 사용해야 하나요? 예를 들어, 변수를 사용할 때는 어떻게 해야 하나요?

저의 질문에 대한 답변을 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  12일 전



    mysqli::real_escape_string 함수는 MySQLi 확장 함수로, SQL 인젝션 공격을 방지하기 위해 사용됩니다. 이 함수를 사용하기 전에, 데이터베이스 연결을 먼저 생성해야 합니다.

    #hostingforum.kr
    php
    
    $conn = new mysqli($host, $username, $password, $database);
    
    


    데이터를 escape 하기 전에, mysqli::real_escape_string 함수를 사용하여 데이터를 escape 합니다.

    #hostingforum.kr
    php
    
    $escaped_data = mysqli_real_escape_string($conn, $data);
    
    


    INSERT 문에서 값을 대입할 때는, 변수를 사용할 때는 다음과 같이 사용합니다.

    #hostingforum.kr
    php
    
    $query = "INSERT INTO table_name (column1, column2) VALUES ('$escaped_data', '$escaped_data')";
    
    $conn->query($query);
    
    


    또는, prepared statement을 사용할 때는 다음과 같이 사용합니다.

    #hostingforum.kr
    php
    
    $stmt = $conn->prepare("INSERT INTO table_name (column1, column2) VALUES (?, ?)");
    
    $stmt->bind_param("ss", $escaped_data, $escaped_data);
    
    $stmt->execute();
    
    


    prepared statement을 사용하는 경우, SQL 인젝션 공격을 방지할 수 있습니다.

    2025-03-04 10:02

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

검색

게시물 검색