필수, 포함, 필수_한 번 및 포함_한 번 포함

WBOY
풀어 주다: 2016-08-08 09:21:53
원래의
954명이 탐색했습니다.

1.require() 문
require() 문은 C 언어의 include() 문과 마찬가지로 문 자체가 아닌 파일을 지정하는 데 사용됩니다. php 구성 파일 php.ini의 URL fopen 래퍼가 켜져 있으면(기본적으로 켜져 있음) URL을 사용하여 파일 위치를 지정하여 원격 파일 호출을 수행할 수 있습니다.
한 가지 중요한 점은 require() 및 include() 문을 사용할 때 특별한 주의를 기울이는 것입니다. 즉, 포함된 파일에서 프로세서는 HTML 모드에 따라 내용을 해석하고, 포함된 내용을 처리한 후 PHP 모드로 복귀한다. 따라서 포함된 파일에서 PHP 구문을 사용해야 하는 경우 올바른 PHP 시작 및 종료 태그를 사용하여 이러한 문을 포함해야 합니다.
require() 및 include()는 함수가 아닌 PHP의 언어 기능입니다. 여러 면에서 기능과 다릅니다.
예를 들어 require()에 포함된 파일은 제어 구조를 포함할 수 없으며 return과 같은 문을 사용할 수 없습니다. require()에 포함된 파일에 return 문을 사용하면 처리 오류가 발생합니다.
include() 문과 달리 require() 문은 이러한 문이 실행되는지 여부에 관계없이 포함된 파일의 내용을 무조건 읽습니다. 따라서 서로 다른 조건에 따라 서로 다른 파일을 포함하려면 include() 문을 사용해야 합니다. 물론 require() 위치에 있는 명령문이 실행되지 않으면 require()가 포함된 파일의 명령문도 실행되지 않습니다.
require()는 루프 본문의 다양한 조건에 따라 다양한 파일을 포함할 수 없습니다. require() 문은 처음 실행될 때 포함된 파일의 내용만 호출하여 문 자체를 대체합니다. 다시 실행되면 처음에 포함된 문만 실행됩니다. 그러나 include() 문은 루프 본문에 다른 파일을 포함할 수 있습니다.
require() 문의 변수는 require() 문이 위치한 변수 범위를 상속합니다. require() 문 위치에서 액세스할 수 있는 모든 변수는 require() 문에 포함된 파일에서 액세스할 수 있습니다. require() 문이 함수 내부에 있는 경우 포함된 파일의 명령문은 함수 내부에서 정의되는 것과 동일합니다.
require() 문은 PHP 프로그램이 실행되기 전에 require가 참조하는 파일을 읽으므로 require는 일반적으로 프로그램 시작 부분에 배치됩니다. 따라서 require 문이 약간 강력하다는 사실에 특별한 주의를 기울여야 합니다. 프로그램에 참조 파일이 실제로 필요한지 여부에 관계없이 require 문을 사용하는 한 해당 파일이 포함됩니다! 이 함수를 사용하여 조건 제어문에 포함시키더라도, 조건이 true가 아니더라도 참조된 파일은 포함됩니다! 좀비가 형성되는 경우, 작전 중에는 눈에 띄는 효과는 없지만, 부담이 확실히 커지니 주의하세요! require 문을 사용하여 포함 오류가 발생하면 프로그램은 오류 메시지를 출력하고 실행을 중지합니다! !
require() 문에 파일의 URL을 선언하여 원격 파일이 포함되어 있고 원격 서버가 PHP 코드에 따라 파일을 해석하는 경우 로컬 PHP 파일에 포함된 내용은 원격에서 처리한 결과입니다. 섬기는 사람. 예:

코드 복사 코드는 다음과 같습니다.


/*
이 예에서는 some_server 서버는 .txt 파일을 해석하지 않고 php 파일을 해석할 수 있습니다. 원격 파일에서
need 변수 $varfirst 및 $varsecond
*/
/*를 올바르게 실행할 수 없습니다. 원격 서버가 .txt 파일을 처리하지 않습니다.*/
require("http:// some_server/file .txt?varfirst=1&varsec>
/*잘못되었으므로 로컬 시스템에서만 file.php 파일을 찾을 수 있습니다.*/
require("file.php?varfirst=1&varsec>
/*올바른 문장 */
require("http://some_server/file.php?varfirst=1&varsec>
$varfirst=1;
$varsec>require("file.txt"); / *올바른 문장 */
require("file.php"); /*올바른 문장*/


원래 php3.0에서는 require()에 포함된 파일에서 return을 사용할 수 있습니다. 그러나 조건은 return 문이 {} 내부에 나타날 수 없고 포함된 파일의 전역 범위에 나타나야 한다는 것입니다. require()의 이 함수는 php4.0에서 취소되었지만 include를 사용하여 계속 구현할 수 있습니다. (). () 문에 적용할 수 없는 부분을 제외하고는 require() 문의 기능을 모두 include() 문에 적용할 수 있습니다. require() 문에는 없습니다.
include 문은 실행 시 포함될 파일만 읽습니다. 오류 처리 편의를 위해 include 오류가 발생하는 경우, 프로그램은 include 문을 건너뜁니다. 오류 메시지가 표시되더라도 프로그램은 계속 실행됩니다.
PHP 프로세서는 include() 문을 만날 때마다 이를 다시 처리합니다. 다양한 상황에 따라 조건부 제어문과 루프문에 include()를 사용할 수 있습니다.
예:

복사 코드코드는 다음과 같습니다.


$files=array('first.php','second.php','third.php')
for($i=0;$i< count($files);$i++)
{
include $files[$i];
}
?>


return 문은 php4.0의 include() 문에 포함된 파일에서 값을 반환하고 포함된 파일 아래의 내용 실행을 중지하는 데 사용할 수 있습니다. 그러나 php3.0과 php4.0은 이러한 상황을 다르게 처리합니다. php3.0에서 return 문은 함수에 있지 않는 한 {} 내에 포함될 수 없습니다. 왜냐하면 return 문은 파일의 반환 값이 아닌 함수의 반환 값을 나타내기 때문입니다. php4.0에서는 그러한 제한이 없습니다. 사용자는 함수의 반환 값처럼 파일에 숫자를 반환할 수도 있습니다. 이러한 명령문은 일반적으로
php3.0에서 오류를 보고합니다. 다음은 예시이다.
포함된 파일이 test.inc이고 메인 파일인 main.php가 디렉터리에 있다고 가정하자. test.inc의 내용은 다음과 같습니다.
test.inc

코드 복사코드는 다음과 같습니다. 다음:


echo "반환 전
n"
if(1)
{
return 27;
echo "After the return
n";
?>


main.php 파일에 다음 명령문이 포함되어 있다고 가정합니다.

코드 복사코드는 다음과 같습니다.

$retval=include('test.inc');
echo "파일 반환됨:' $retval'
n";
?>


php3.0 인터프리터는 두 번째 줄에서 오류를 보고합니다. include() 문 값의 반환을 얻을 수 없습니다. 그러나 php4.0에서는 다음과 같은 결과를 얻게 됩니다:
반환 전
반환된 파일: '27'
가정 아래 main.php는 다음과 같이 변경됩니다.

코드 복사 코드는 다음과 같습니다.

include( 'test.inc');
echo "main.html로 돌아가기"
?>


php4.0은 다음과 같습니다.
반환 전
main.html로 돌아가기
php5.0의 출력 결과도 다음과 같습니다.
반환 전
main.html로 돌아가기
php3.0의 출력 결과는 다음과 같습니다.
반환 전
27main.html로 돌아가기
파싱 오류:5행의 /apache/htdocs/phptest/main.html에 파싱 오류
위 오류는 return 문이 함수 내부가 아닌 {} 내부에 있기 때문에 발생합니다. test.inc의 가장 바깥쪽 레이어에 위치하도록 {}를 제거하면 출력 결과는 다음과 같습니다.
Before the return
27Back in main.html
27이 나타나는 이유는 php3.0에서는 include() return을 지원하지 않기 때문입니다.
3.require_once() 및 include_once() 문
require_once() 및 include_once() 문은 각각 require() 및 include() 문에 해당합니다. require_once() 및 include_once() 문은 여러 파일을 포함해야 할 때 주로 사용되며, 이는 동일한 코드 조각을 포함하여 발생하는 함수 또는 변수의 반복 정의 오류를 효과적으로 방지할 수 있습니다. 예: util.inc 및 foo.inc라는 두 개의 파일을 생성하는 경우 프로그램 코드는 다음과 같습니다.
util.inc:

복사 code 코드는 다음과 같습니다:

define(PHPVERSION,floor(phpversion()))
echo "GLOBALS ARE NICE< br>n" ;
function goodTea()
{
return "오롱차 맛있어요!";
}
?>


및 Fool.inc :

코드 복사코드는 다음과 같습니다.

require ("util.inc" );
function showVar($var)
{
if(PHPVERSION==4)
{
print_r($var)
}
else
{
var_dump($var);
}
}
?>


그런 다음 error_require에 이 두 파일을 포함시킵니다. php:

코드 복사코드는 다음과 같습니다.

require(" Fool.inc");
require("util.inc");//이 문장은 오류를 생성합니다
$foo=array("1",array("complex","quaternion"));
echo "이 역시
n인 util .inc가 필요합니다.";
echo "fool.incn에 필요합니다."
echo "goodTea:".goodTea()를 실행합니다."< br>n";
echo "foo 인쇄 중:
n";
showVar($foo);
?>


error_require.php가 실행되면 출력은 다음과 같습니다.
GLOBALS ARE NICE
GLOBALS ARE NICE
치명적인 오류: Cannot redeclare goodTea() in util.inc on line 4
require() 문 대신 require_once() 문을 사용하면 위 오류가 발생하지 않습니다. error_require.php 및 foo.inc의 require() 문을 require_once() 문으로 변경하고 이름을 error_require_once.php로 바꿨습니다.
GLOBALS ARE NICE
이것은 util.inc가 다시 필요하며, 이는 Fool.inc에도 필요합니다
Running goodTea:Olong tea 맛있습니다! 🎜>
Array([0] => 1 [1] => 배열 ([0] => 복소수 [1] = 쿼터니언))
include_once( ) 문의 구문은 include()와 유사합니다. 주요 차이점은 파일을 여러 번 포함함으로써 발생하는 함수나 변수의 정의가 반복되지 않는다는 것입니다.
require_once 문에는 파일이 프로그램에 한 번만 추가되고 변수 값과 함수 이름 간의 충돌을 방지하는 참조 체인이 있습니다.
require_once 문과 동일하게 include_once 문은 include 기능을 확장합니다. 프로그램 실행 중에 지정된 파일이 포함됩니다. 파일에서 참조된 프로그램이 이전에 포함된 경우 include_once()는 해당 파일을 다시 포함하지 않습니다. 즉, 동일한 파일은 한 번만 참조될 수 있습니다!
include_once() 문은 스크립트 실행 중에 지정된 파일을 포함하고 실행합니다. 이 동작은 include() 문과 유사합니다. 유일한 차이점은 파일의 코드가 이미 포함된 경우 다시 포함되지 않는다는 것입니다. 이 명령문의 이름에서 알 수 있듯이 한 번만 포함됩니다.
include_once()는 스크립트 실행 중에 동일한 파일이 두 번 이상 포함될 수 있으며, 함수 재정의 및 변수 재할당과 같은 문제를 피하기 위해 한 번만 포함되도록 해야 할 때 사용해야 합니다. .
require_once() 및 include_once() 사용에 대한 더 많은 예를 보려면 최신 PHP 소스 배포 패키지의 PEAR 코드를 참조하세요.
반환값은 include()와 동일합니다. 파일이 포함된 경우 이 함수는 TRUE를 반환합니다.
참고: PHP 4.0.1pl2에는 include_once()가 새로 추가되었습니다.
참고: 대소문자를 구분하지 않는 운영 체제(예: Windows)
에서는 include_once() 및 require_once()의 동작이 예상되지 않을 수 있다는 점에 유의하세요.
예: Windows에서 include_once()는 대소문자를 구분하지 않습니다.
코드 복사

코드는 다음과 같습니다. include_once("a.php"); // 여기에는 a.php가 포함됩니다.

include_once("A.php") // 여기에는 포함됩니다. Windows에서는 다시 a.php를 사용하세요! (PHP 4에만 해당)

?>



이 동작은 PHP 5에서 변경되었으며 경로가 먼저 정규화되므로 C:PROGRA~1A .php C:Program Filesa.php 구현과 마찬가지로 파일은 한 번만 포함됩니다.


포함할 파일이 존재하지 않으면 include는 알림 메시지를 표시한 후 다음 명령문을 계속 실행하면 require는 치명적인 오류를 메시지로 표시하고 종료됩니다.
win32 플랫폼에서는 먼저 포함된 후 실행되므로 포함된 파일에 include 또는 require 문을 두지 않는 것이 가장 좋습니다. 이는 디렉터리 혼란을 야기합니다. Linux에서는 상황이 다를 수도 있습니다. 아직 테스트하지 않았습니다.
파일을 여러 번 포함하고 싶지 않은 경우에는 include_once 또는 require_once##를 사용하여 문서 데이터를 읽고 쓸 수 있습니다.
코드 복사

코드는 다음과 같습니다.function r($file_name ) {

$filenum=@fopen($file_name,"r");

@flock($filenum,LOCK_SH)
$file_data=@fread($filenum,filesize($file_name));
@fclose($filenum);
return $file_data;
}
function w($file_name,$data,$method="w"){
$filenum=@fopen( $file_name, $method);
Flock($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data)
return $file_data; 🎜>}

위에서는 관련 측면을 포함하여 require, include, require_once 및 include_once의 차이점을 소개했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.


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