> PHP 프레임워크 > ThinkPHP > thinkphp I 메소드 소개

thinkphp I 메소드 소개

풀어 주다: 2020-05-10 09:03:02
앞으로
3340명이 탐색했습니다.

thinkphp I 메소드 소개

보시다시피 I 메소드는 ThinkPHP의 많은 단일 문자 함수 중 새로운 멤버입니다. 그 이름은 주로 시스템 입력 변수를 보다 편리하고 안전하게 가져오는 데 사용됩니다. Anywhere를 사용할 수 있으며 사용 형식은 다음과 같습니다.

I('变量类型.变量名',['默认值'],['过滤方法'])
로그인 후 복사

변수 유형은 다음을 포함하여 요청 방법 또는 입력 유형을 나타냅니다.

thinkphp I 메소드 소개

참고: 변수 유형은 대소문자를 구분하지 않습니다.

변수 이름은 대소문자를 엄격하게 구분합니다.

기본값과 필터링 방법은 선택적 매개변수입니다.

Usage

I 메소드의 사용을 설명하기 위해 GET 변수 유형을 예로 들어 보겠습니다.

echo I('get.id'); // 相当于 $_GET['id']
echo I('get.name'); // 相当于 $_GET['name']
로그인 후 복사

지원 기본값:

echo I('get.id',0); // 如果不存在$_GET['id'] 则返回0
echo I('get.name',''); // 如果不存在$_GET['name'] 则返回空字符串
로그인 후 복사

메서드 필터링 사용:

echo I('get.name','','htmlspecialchars'); // 采用htmlspecialchars方法对$_GET['name'] 进行过滤,如果不存在则返回空字符串
로그인 후 복사

전체 변수 유형 직접 획득 지원 예:

I('get.'); // 获取整个$_GET 数组
로그인 후 복사

사용 동일한 방법으로 post 또는 기타 입력 유형의 변수를 얻을 수 있습니다. 예:

I('post.name','','htmlspecialchars'); // 采用htmlspecialchars方法对$_POST['name'] 进行过滤,如果不存在则返回空字符串
I('session.user_id',0); // 获取$_SESSION['user_id'] 如果不存在则默认为0
I('cookie.'); // 获取整个 $_COOKIE 数组
I('server.REQUEST_METHOD'); // 获取 $_SERVER['REQUEST_METHOD']
로그인 후 복사

param 변수 유형은 현재 요청 유형의 자동 결정을 지원하는 프레임워크별 변수 획득 방법입니다. 예:

echo I('param.id');
로그인 후 복사

현재 요청 유형이 GET인 경우 $_GET['id']와 동일합니다. 현재 요청 유형이 POST 또는 PUT인 경우 $_POST['id'] 또는 PUT 매개변수 ID.

그리고 매개변수 유형 변수는 숫자 인덱스를 사용하여 URL 매개변수를 얻을 수도 있습니다(PATHINFO 모드 매개변수는 GET이든 POST이든 유효해야 합니다). 예:

현재 액세스된 URL 주소는

http://serverName/index.php/New/2013/06/01
로그인 후 복사

그런 다음 전달할 수 있습니다.

echo I('param.1'); // 输出2013
echo I('param.2'); // 输出06
echo I('param.3'); // 输出01
로그인 후 복사

실제로 param 변수 유형의 작성은 다음과 같이 단순화될 수 있습니다.

I('id'); // 等同于 I('param.id')
I('name'); // 等同于 I('param.name')
로그인 후 복사

변수 필터링

I 메서드를 사용할 때 변수는 실제로 두 개의 필터를 거칩니다. 첫 번째는 전역 필터링입니다. VAR_FILTERS 매개변수를 구성하면 버전 3.1 이후에는 VAR_FILTERS 매개변수의 필터링 메커니즘이 array_walk_recursive 메서드를 사용하여 재귀적으로 필터링하도록 변경되었다는 점에 유의해야 합니다. 필터링 메서드에 대한 주요 요구 사항은 참조로 반환되어야 한다는 것입니다. , 따라서 여기에서 htmlspecialchars를 설정하는 것은 유효하지 않습니다. 예를 들어

function filter_default(&$value){
    $value = htmlspecialchars($value);
 }
로그인 후 복사

그런 다음 다음을 구성합니다.

'VAR_FILTERS'=>'filter_default'
로그인 후 복사

여러 번 필터링해야 하는 경우 다음을 사용할 수 있습니다.

'VAR_FILTERS'=>'filter_default,filter_exp'
로그인 후 복사

filter_exp 메소드는 내장된 보안입니다. 모델의 EXP 함수를 사용하여 주입 공격을 방지하는 데 사용되는 프레임워크의 필터링 방법입니다.

VAR_FILTERS 매개변수는 전역 필터링 메커니즘을 설정하고 재귀 필터링을 사용하므로 효율성에 영향을 미치므로 I 메서드의 세 번째 매개변수에 필터링 방법을 설정하는 것 외에도 변수를 직접 필터링하는 것이 좋습니다. , DEFAULT_FILTER 매개변수를 구성하여 필터링을 설정할 수도 있습니다. 실제로 이 매개변수의 기본 설정은

'DEFAULT_FILTER'        => 'htmlspecialchars'
로그인 후 복사

입니다. 즉, I 메서드의 모든 획득 변수는 htmlspecialchars로 필터링된 다음

I('get.name'); // 等同于 htmlspecialchars($_GET['name'])
로그인 후 복사

입니다. 마찬가지로 이 매개변수는 여러 필터를 지원할 수도 있습니다. 예:

'DEFAULT_FILTER'        => 'strip_tags,htmlspecialchars'
로그인 후 복사
I('get.name'); // 等同于 htmlspecialchars(strip_tags($_GET['name']))
로그인 후 복사

I 메서드를 사용할 때 필터 메서드를 지정하면 DEFAULT_FILTER 설정이 무시됩니다. 예:

echo I('get.name','','strip_tags'); // 等同于 strip_tags($_GET['name'])
로그인 후 복사

I의 세 번째 매개변수가 메소드가 함수 이름에 전달되면 이 함수를 호출하여 변수를 필터링하고 반환한다는 의미입니다(변수가 배열인 경우 array_map은 자동으로 필터링에 사용됩니다). 그렇지 않으면 PHP의 내장 filter_var 메소드가 필터링을 위해 호출됩니다. 예:

I('post.email','',FILTER_VALIDATE_EMAIL);
로그인 후 복사

는 $_POST가 필터링됨을 의미합니다. ['email']은 형식 확인을 수행하고 요구 사항을 충족하지 않는 경우 빈 문자열을 반환합니다.

또는 다음 문자 식별 방법을 사용할 수 있습니다.

I('post.email','','email');
로그인 후 복사

지원되는 필터 이름은 filter_list 방법에서 유효한 값이어야 합니다(서버 환경에 따라 다를 수 있음). 가능한 지원 항목은

  • int입니다.

  • boolean

  • float

  • validate_regexp

  • validate_url

  • validate_email

  • validate_ip

  • 문자열

  • stripped

  • encoded

  • special_chars

  • unsafe_raw

  • email

  • url

  • number_int

  • number_float

  • magic_quotes

  • callback

특수한 경우에는 공연을 하고 싶지 않을 수도 있습니다 모든 필터링, DEFAULT_FILTER가 설정된 경우에도 다음을 사용할 수 있습니다.

I('get.name','',NULL);
로그인 후 복사

필터링 매개변수가 NULL로 설정되면 필터링이 수행되지 않음을 의미합니다.

추천 튜토리얼: "TP5"

위 내용은 thinkphp I 메소드 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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