개발자 Q&A

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

2025.07.21 11:45

mysql_real_escape_string 함수 사용에 대한 질문

목록
  • 패턴마스터 1일 전 2025.07.21 11:45
  • 17
    1
저는 mysql_real_escape_string 함수를 사용하여 데이터베이스에 입력된 값을 안전하게 처리하고자 합니다.
하지만, 이 함수의 사용법이 조금 혼란스럽습니다.

mysql_real_escape_string 함수는 어떤 역할을 하는가요?
그리고, 이 함수를 사용할 때 어떤 특수 문자를 처리해야 하나요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysql_real_escape_string 함수는 MySQL 데이터베이스에서 사용되는 문자열을 안전하게 처리하기 위해 사용되는 함수입니다. 이 함수는 SQL 인젝션 공격을 방지하기 위해 특수 문자를 처리하는 역할을 합니다.

    특수 문자는 다음과 같습니다.

    - \ (백슬래시)
    - ' (작은 따옴표)
    - " (큰 따옴표)
    - \n (라인 피드)
    - \r (캐리지 리턴)
    - \t (탭)
    - \b (백스페이스)
    - \0 (널 문자)
    - % (퍼센트)
    - _ (언더스코어)
    - ' (작은 따옴표)
    - " (큰 따옴표)

    이러한 특수 문자를 처리하기 위해 mysql_real_escape_string 함수를 사용하면, 데이터베이스에 입력된 값을 안전하게 처리할 수 있습니다.

    예를 들어, 다음과 같이 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    
    
    $unsafe_value = "John's 'quote";
    
    $safe_value = mysql_real_escape_string($unsafe_value);
    
    
    
    $mysqli->query("INSERT INTO users (name) VALUES ('$safe_value')");
    
    


    위의 예제에서, mysql_real_escape_string 함수를 사용하여 $unsafe_value 변수의 값을 처리한 후, 데이터베이스에 INSERT 문을 실행합니다. 이로써, SQL 인젝션 공격을 방지할 수 있습니다.

    2025-07-21 11:46

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

검색

게시물 검색