SQL 인젝션을 방지하는 가장 완벽한 방법

WBOY
풀어 주다: 2016-07-29 08:56:11
원래의
1470명이 탐색했습니다.
(1) mysql_real_escape_string - 연결의 현재 문자 세트를 고려하여 SQL 문에 사용된 문자열의 특수 문자를 이스케이프합니다.

다음과 같이 사용됩니다:

?

1

2

3

$sql= "select count(*) asctr from users where username

='".mysql_real_escape_string($username)."'and

password='". mysql_real_escape_string($pw)."'limit 1";

123
$sql= "개수( 선택 *) username='".mysql_real_escape_string($username)인 사용자의 ctr입니다. "'비밀번호='". mysql_real_escape_string($pw)."'제한 1";

사용자 입력에 악의적인 SQL 삽입을 방지하려면

mysql_real_escape_string()

을 사용자 입력 주위의 래퍼로 사용하세요.

(2) SQL 주입을 방지하려면 Magic_quotes_gpc를 켜세요.

php.ini에 설정이 있습니다: Magic_quotes_gpc = Off

기본적으로 꺼져 있는 경우입니다. '를'로 변환하는 등 사용자가 제출한 SQL 쿼리

를 자동으로 변환하는 것은 SQL 주입을 방지하는 데 중요한 역할을 합니다.

Magic_quotes_gpc=Off인 경우 addlashes() 함수를 사용하세요

(3) Custom 함수

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

functioninject_check($sql_str) {

    returneregi('select|insert|and|or|update|delete|'|/*|*|../|./|union|into|load_file|outfile' , $sql_str);

}

functionverify_id($id=null) {

    if(!$id) {

        exit('没有提交参数!');

    } elseif(inject_check($id)) {

        exit('提交的参数非法!');

    } elseif(!is_numeric($id )) {

        exit('提交的参数非法!');

    }

    $id= intval($id);

     

    return$id;

}

functionstr_check( $str) {

    if(!get_magic_quotes_gpc()) {

        $str= addslashes ($str); // 进行过滤

    }

    $str= str_replace("_", "_", $str);

    $str= str_replace("%", "%", $str);

     

   return$str;

}

functionpost_check( $post) {

    if(!get_magic_quotes_gpc()) {

        $post= addslashes($post);

    }

    $post= str_replace("_", "_", $post);

    $post= str_replace("%", "%", $post);

    $post = nl2br($post);

    $post= htmlspecialchars($post);

     

    return$post;

}

이상에서는 모든 측면을 포함하여 SQL 주입을 방지하는 가장 완벽한 방법을 소개했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!