PHP 슈퍼전역 변수 소개

不言
풀어 주다: 2023-04-02 14:16:01
원래의
1611명이 탐색했습니다.

PHP 4.1.0에 도입된 Superglobal 변수는 모든 범위에서 항상 사용할 수 있는 내장 변수입니다.

수퍼전역 변수 — 수퍼전역 변수는 모든 범위에서 항상 사용할 수 있는 내장 변수입니다.

PHP에서 미리 정의된 많은 변수는 "수퍼글로벌"입니다. 즉, 스크립트의 전체 범위에서 사용할 수 있습니다. global $variable;을 실행하지 않고도 함수나 메서드 내에서 액세스할 수 있습니다.

이 슈퍼 전역 변수는 다음과 같습니다.

$GLOBALS — 전역 범위에서 사용 가능한 모든 변수를 참조합니다.

모든 변수를 포함하는 전역 조합 배열. 변수의 이름은 배열의 키입니다. global의 기능은 전역 변수를 정의하는 것이지만 이 전역 변수는 전체 웹 사이트에 적용되는 것이 아니라 현재 페이지(include 또는 require에 있는 모든 파일 포함)에 적용됩니다. 단, 함수 본문 내에 정의된 전역 변수는 함수 본문 내에서 사용할 수 있으며, 함수 본문 외부에서 정의한 전역 변수는 함수 본문 내에서 사용할 수 없습니다. (1) 함수 본문 내에서 사용할 수 있는 전역 변수를 함수 본문에 정의합니다.

<?php

function test(){
    $foo = "local variable";
    echo &#39;$foo in global scope:&#39;.$GLOBALS[&#39;foo&#39;].&#39;<br />&#39;;//$foo in global scope:Example content
    echo &#39;$foo in current scope:&#39;.$foo.&#39;<br />&#39;;//$foo in current scope:local variable
    $GLOBALS[&#39;foo&#39;] = &#39;1111&#39;;
    echo &#39;$foo in global scope:&#39;.$GLOBALS[&#39;foo&#39;].&#39;<br />&#39;;//$foo in global scope:1111}
$foo = "Example content";
test();
echo $foo.&#39;<br />&#39;;//1111
로그인 후 복사

(2) 전역 변수는 함수 몸체 외부에서 정의하고 함수 몸체 내부에서는 사용할 수 없습니다.

<?= = ] = $GLOBALS[] + $GLOBALS[];.$b.;
로그인 후 복사

$_SERVER --

$HTTP_SERVER_VARS [삭제됨] —

서버 및 실행 환경 정보

(헤더), 경로( 경로) 및 정보의 배열 예를 들어 스크립트 위치(스크립트 위치). 이 배열의 항목은 웹 서버에 의해 생성됩니다. 모든 서버가 모든 항목을 제공한다는 보장은 없습니다. 서버는 일부 항목을 무시하거나 여기에 나열되지 않은 항목을 제공할 수 있습니다.

다음 표에는 $_SERVER에서 액세스할 수 있는 가장 중요한 요소가 나열되어 있습니다.

요소/코드 Description
$_SERVER['PHP_SELF']현재 실행 중인 스크립트의 파일 이름을 반환합니다.
$_SERVER['GATEWAY_INTERFACE']서버에서 사용하는 CGI 사양의 버전을 반환합니다.
$_SERVER['SERVER_ADDR']스크립트가 현재 실행 중인 서버의 IP 주소를 반환합니다.
$_SERVER['SERVER_NAME']스크립트가 현재 실행 중인 서버의 호스트 이름을 반환합니다.
$_SERVER['SERVER_SOFTWARE']서버 식별 문자열(예: Apache/2.2.24)을 반환합니다.
$_SERVER['SERVER_PROTOCOL']페이지가 요청되었을 때 통신 프로토콜의 이름과 버전을 반환합니다(예: "HTTP/1.0").
$_SERVER['REQUEST_METHOD']페이지에 액세스하는 데 사용되는 요청 방법(예: POST)을 반환합니다.
$_SERVER['REQUEST_TIME']요청이 시작된 타임스탬프를 반환합니다(예: 1577687494).
$_SERVER['QUERY_STRING']쿼리 문자열을 통해 이 페이지에 액세스한 경우 쿼리 문자열을 반환합니다.
$_SERVER['HTTP_ACCEPT']현재 요청에서 요청 헤더를 반환합니다.
$_SERVER['HTTP_ACCEPT_CHARSET']현재 요청(예: utf-8, ISO-8859-1)에서 Accept_Charset 헤더를 반환합니다.
$_SERVER['HTTP_HOST']Accept_Charset를 반환합니다. 현재 요청 호스트 헤더의 헤더입니다.
$_SERVER['HTTP_REFERER'] 현재 페이지의 전체 URL을 반환합니다(모든 사용자 에이전트에서 지원되지 않으므로 신뢰할 수 없음).
$_SERVER['HTTPS']보안 HTTP 프로토콜을 통해 스크립트를 쿼리할지 여부입니다.
$_SERVER['REMOTE_ADDR']현재 페이지를 탐색하는 사용자의 IP 주소를 반환합니다.
$_SERVER['REMOTE_HOST']현재 페이지를 탐색하는 사용자의 호스트 이름을 반환합니다.
$_SERVER['REMOTE_PORT']사용자 컴퓨터의 웹 서버에 연결하는 데 사용되는 포트 번호를 반환합니다.
$_SERVER['SCRIPT_FILENAME']현재 실행 중인 스크립트의 절대 경로를 반환합니다.
$_SERVER['SERVER_ADMIN']이 값은 Apache 서버 구성 파일의 SERVER_ADMIN 매개변수를 지정합니다.
$_SERVER['SERVER_PORT']웹 서버에서 사용하는 포트입니다. 기본값은 "80"입니다.
$_SERVER['SERVER_SIGNATURE']서버 버전과 가상 호스트 이름을 반환합니다.
$_SERVER['PATH_TRANSLATED']현재 스크립트가 위치한 파일 시스템의 기본 경로(문서 루트 디렉터리 아님)입니다.
$_SERVER['SCRIPT_NAME']현재 스크립트의 경로를 반환합니다.
$_SERVER['SCRIPT_URI']현재 페이지의 URI를 반환합니다.

<?php

echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($_SERVER);
로그인 후 복사

$_GET -- $HTTP_GET_VARS [已弃用] — HTTP GET 变量

通过 URL 参数传递给当前脚本的变量的数组。

$_POST -- $HTTP_POST_VARS [已弃用] — HTTP POST 变量

当 HTTP POST 请求的 Content-Type 是 application/x-www-form-urlencoded 或 multipart/form-data 时,会将变量以关联数组形式传入当前脚本。

$_FILES -- $HTTP_POST_FILES [已弃用] — HTTP 文件上传变量

通过 HTTP POST 方式上传到当前脚本的项目的数组。

$_COOKIE -- $HTTP_COOKIE_VARS [已弃用] — HTTP Cookies

通过 HTTP Cookies 方式传递给当前脚本的变量的数组。

$_SESSION -- $HTTP_SESSION_VARS [已弃用] — Session 变量

当前脚本可用 SESSION 变量的数组

$_REQUEST — HTTP Request 变量

$_ENV -- $HTTP_ENV_VARS [已弃用] — 环境变量

通过环境方式传递给当前脚本的变量的数组。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

php中imagettfbbox和imagettftext 文字图片自动换行的方法

PHP中的常见魔术方法功能作用及用法

위 내용은 PHP 슈퍼전역 변수 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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