개발자 Q&A

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

2025.03.19 20:59

addslashes 함수 사용법에 대해 설명해 주세요

목록
  • RESTful도령 8시간 전 2025.03.19 20:59 새글
  • 3
    1
제가 공부를 하면서 MySQL에서 문자열을 저장할 때 addslashes 함수를 사용하는데, 이 함수는 어떤 역할을 하는 것일까요? 예를 들어, MySQL에서 문자열을 저장할 때 사용하는 방식과 addslashes 함수를 사용했을 때의 차이점은 무엇일까요?

예를 들어, MySQL에서 다음 문자열을 저장하려고 합니다.
sql

SELECT * FROM 테이블 WHERE 이름 = '홍길동';


이 때, addslashes 함수를 사용하면 어떻게 될까요?

또한, MySQL에서 문자열을 저장할 때 addslashes 함수를 사용하지 않았을 때의 위험은 무엇일까요?

제가 이해한 바에 따라서 올바르게 addslashes 함수를 사용하는 방법을 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  8시간 전



    MySQL에서 문자열을 저장할 때 addslashes 함수는 특수 문자를 이스케이프 처리하는 역할을 합니다. 예를 들어, MySQL에서 문자열을 저장할 때 사용하는 방식은 다음과 같습니다.

    #hostingforum.kr
    sql
    
    SELECT * FROM 테이블 WHERE 이름 = '홍길동';
    
    


    이 때, addslashes 함수를 사용하면 다음과 같이 이스케이프 처리가 됩니다.

    #hostingforum.kr
    sql
    
    SELECT * FROM 테이블 WHERE 이름 = '홍길동';
    
    


    addslashes 함수를 사용하지 않았을 때의 위험은 SQL 인젝션 공격에 노출될 수 있습니다. 예를 들어, 사용자가 입력한 문자열을 저장할 때 addslashes 함수를 사용하지 않았을 경우, 다음과 같은 공격이 가능합니다.

    #hostingforum.kr
    sql
    
    SELECT * FROM 테이블 WHERE 이름 = '홍길동' OR 1=1;
    
    


    이 공격은 MySQL에서 SQL 문법을 조작하여 데이터를 노출하거나 삭제할 수 있습니다. 따라서 addslashes 함수를 사용하여 문자열을 이스케이프 처리하는 것이 중요합니다.

    올바르게 addslashes 함수를 사용하는 방법은 다음과 같습니다.

    #hostingforum.kr
    php
    
    문자열 = addslashes(입력 문자열);
    
    


    예를 들어, 사용자가 입력한 문자열을 저장할 때 다음과 같이 addslashes 함수를 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $입력_문자열 = '홍길동';
    
    $문자열 = addslashes($입력_문자열);
    
    $sql = "SELECT * FROM 테이블 WHERE 이름 = '$문자열';";
    
    


    이러한 방법으로 addslashes 함수를 사용하여 문자열을 이스케이프 처리할 수 있습니다.

    2025-03-19 21:00

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

검색

게시물 검색