>类库下载 >PHP类库 >PHP 약한 유형 안전 문제

PHP 약한 유형 안전 문제

高洛峰
高洛峰원래의
2016-10-09 13:29:161143검색

PHP 약한 유형 안전 문제에 대한 참고 사항

1. 유형 변환 문제

intval();

 

    var_dump(intval('1asdfasd'));  //1

    var_dump(intval('awqw12'));  //0

    var_dump(intval(array()));    //0

    var_dump(intval(array('foo','val'))); //1

    var_dump(intval(0x1A)); //26  十六进制转换

    var_dump(intval('asdfqwer')); //0

intval 값을 문자열로 변환하면 오류가 반환되지 않지만 0이 반환됩니다. 값이 배열인 경우에는 두 가지 상황이 있습니다. 변환된 값이 빈 배열인 경우 0이 반환되고, 그렇지 않으면 1이 반환됩니다.

참고: PHP는 저장을 위해 32비트 메모리를 사용합니다. 32비트는 4294967296을 나타낼 수 있습니다. 숫자는 부호가 있는 경우 -2147483647 ~ 2147483648입니다.

2. 내장 함수의 느슨함 문제

switch();
 
 
 
    $i='3adcd';
 
    switch($i){
 
             case 1:
 
                    echo 'i is 1';
 
                    break;
 
             case 2:
 
                    echo 'i is 2';
 
                    break;
 
             case 3:
 
                    echo 'i is 3';
 
                    break;
 
             default:
 
                   echo 'i is default';
 
                   break;
 
    }

위 결과는 스위치 케이스 3에 들어가게 되는데 왜 그럴까요? 스위치가 숫자형 케이스라면 스위치는 매개변수를 int 클래스로 변환하므로 위의 실행 시 $i가 타입 변환됩니다. 먼저 변환 결과는 3입니다. . .

in_array();

    $arr = [0,1,2,3,'test'];

    var_dump(in_array('abd',$arr));    // true

    var_dump(in_array('1bc',$arr));    // true

위 실행 결과가 왜 이럴까요? 매뉴얼에 문의해보니 in_array는 기본적으로 값이 같은지 여부만 비교하는 느슨한 비교 방식으로 되어 있다고 합니다. 값 유형이 동일한지 비교하기 때문에 위와 같은 결과가 나오지만 in_array 함수의 세 번째 매개변수를 True로 설정하면 엄격한 비교 방법이 됩니다.

위 내용은 일상생활에서 주의해야 할 사항입니다.


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

관련 기사

더보기