개발자 Q&A

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

2025.07.05 09:27

mysqli::execute_query 관련 질문

목록
  • Scala마법사 1일 전 2025.07.05 09:27
  • 17
    1
저는 mysqli::execute_query를 사용하여 MySQL 데이터베이스에 쿼리를 실행하려고 하는데,
어떻게 query string에 변수를 넣어야 하는지 궁금합니다.

예를 들어, 다음과 같은 쿼리 string이 있다고 가정해 보겠습니다.

php

$query = "SELECT * FROM users WHERE id = '$id' AND name = '$name'";



이러한 쿼리 string에 변수를 넣는 방법이 궁금합니다.

그리고, 이 방법이 보안에 취약한가요? 어떻게 보안을 강화할 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysqli::execute_query를 사용하여 MySQL 데이터베이스에 쿼리를 실행할 때, query string에 변수를 넣는 방법은 다음과 같습니다.

    1. prepared statement 사용: MySQLi의 prepared statement 기능을 사용하여 쿼리와 변수를 분리할 수 있습니다. 예를 들어, 다음과 같이 쿼리와 변수를 분리한 후 prepared statement를 사용하여 쿼리를 실행할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM users WHERE id = ? AND name = ?");
    
    $stmt->bind_param("si", $id, $name);
    
    $stmt->execute();
    
    


    2. query string에 변수 직접 삽입: query string에 변수를 직접 삽입할 경우, 변수를 문자열로 감싸는 방법을 사용할 수 있습니다. 예를 들어, 다음과 같이 변수를 문자열로 감쌉니다.

    #hostingforum.kr
    php
    
    $query = "SELECT * FROM users WHERE id = '$id' AND name = '$name'";
    
    


    그러나, 이 방법은 보안에 취약하므로 사용을 권장하지 않습니다.

    3. query string에 변수 직접 삽입 (mysqli_real_escape_string 사용): query string에 변수를 직접 삽입할 경우, mysqli_real_escape_string 함수를 사용하여 변수를 안전하게 삽입할 수 있습니다. 예를 들어, 다음과 같이 변수를 안전하게 삽입합니다.

    #hostingforum.kr
    php
    
    $query = "SELECT * FROM users WHERE id = '" . mysqli_real_escape_string($mysqli, $id) . "' AND name = '" . mysqli_real_escape_string($mysqli, $name) . "'";
    
    


    그러나, 이 방법도 보안에 취약하므로 사용을 권장하지 않습니다.

    보안을 강화하기 위해서는 prepared statement를 사용하는 것을 권장합니다. prepared statement를 사용하면 쿼리와 변수를 분리하여 보안을 강화할 수 있습니다.

    2025-07-05 09:28

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

검색

게시물 검색