PHP 전역 변수 - 슈퍼전역 변수

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

PHP 전역 변수 - 슈퍼 전역 변수

PHP에서 미리 정의된 많은 변수는 "슈퍼 전역"입니다. 즉, 스크립트의 모든 범위에서 사용할 수 있습니다. . 전역

$variablename;을 실행하지 않고도 함수나 메서드 내에서 액세스할 수 있습니다.

PHP 슈퍼 전역 변수 목록:

·  $GLOBALS

· $_SERVER

· $_REQUEST

· $_POST

· $_GET

· $_FILES

· $_ENV

· $_COOKIE

· $_SESSION

이것 이 장에서는 일반적으로 사용되는 몇 가지 슈퍼 전역 변수에 대해 설명하고 나머지 변수는 다음 몇 장에서 소개합니다. PHP 스크립트의 전체 범위에서 접근할 수 있는 PHP의 슈퍼 전역 변수 그룹입니다.
$GLOBALS는 모든 변수를 포함하는 전역 결합 배열입니다. 변수의 이름은 배열의 키입니다.


예제

다음 예는 슈퍼 전역 변수 $GLOBALS를 사용하는 방법을 보여줍니다. :

<?php
 $x = 75;
 $y = 25;
 function addition()
 {
     $GLOBALS['z'] = $GLOBALS['x'] + $GLOBALS['y'];
 }
 addition();
 echo $z;
 ?>

프로그램 실행 결과:

100

위의 예에서 z는 a입니다. $ 함수 외부에서도 접근할 수 있는 GLOBALS 배열의 슈퍼 전역 변수입니다.


PHP $_SERVER

$_SERVER는 헤더, 경로, 스크립트 위치 등의 정보가 포함된 파일입니다. 이 배열의 항목은 웹 서버에 의해 생성됩니다. 모든 서버가 모든 항목을 제공한다는 보장은 없습니다. 서버는 일부 항목을 무시하거나 여기에 나열되지 않은 항목을 제공할 수 있습니다.

다음 예는 $_SERVER의 요소를 사용하는 방법을 보여줍니다.

<?php
 echo $_SERVER['PHP_SELF'];
 echo "<br>";
 echo $_SERVER['SERVER_NAME'];
 echo "<br>";
 echo $_SERVER['HTTP_HOST'];
 echo "<br>";
 echo $_SERVER['HTTP_REFERER'];
 echo "<br>";
 echo $_SERVER['HTTP_USER_AGENT'];
 echo "<br>";
 echo $_SERVER['SCRIPT_NAME'];
 ?>

프로그램 실행 결과:

/Basis/superglobals/superglobals_1.php
localhost
localhost
http://localhost/Basis/superglobals/
Mozilla/5.0(Windows NT 6.1 ; Win64;

요소/코드
설명



$_SERVER['PHP_SELF']

문서 루트와 관련된 현재 실행 중인 스크립트의 파일 이름입니다. 예를 들어, http://example.com/test.php/foo.bar의 스크립트에서 $_SERVER['PHP_SELF']를 사용하면 /test.php/foo.bar가 됩니다. __FILE__ 상수에는 현재(즉, 포함하는) 파일의 전체 경로와 파일 이름이 포함됩니다. PHP 버전 4.3.0부터 PHP가 명령줄 모드에서 실행 중인 경우 이 변수에는 스크립트 이름이 포함됩니다. 이 변수는 이전 버전에서는 사용할 수 없습니다.

$_SERVER['GATEWAY_INTERFACE']
서버에서 사용하는 CGI 사양의 버전입니다(예: "CGI/1.1").
$_SERVER['SERVER_ADDR']현재 스크립트가 실행 중인 서버의 IP 주소입니다.

$_SERVER['SERVER_NAME']

스크립트가 현재 실행 중인 서버의 호스트 이름입니다. 스크립트가 가상 호스트에서 실행 중인 경우 이름은 해당 가상 호스트에 설정된 값에 따라 결정됩니다. (예: www.php.cn)
$_SERVER['SERVER_SOFTWARE']服务器标识字符串,在响应请求时的头信息中给出。(如:Apache/2.2.24)
$_SERVER['SERVER_PROTOCOL']请求页面时通信协议的名称和版本。例如,"HTTP/1.0"。
$_SERVER['REQUEST_METHOD']访问页面使用的请求方法;例如,"GET", "HEAD","POST","PUT"。


$_SERVER['REQUEST_TIME']

请求开始时的时间戳。从 PHP 5.1.0 起可用。 (如:1377687496)
$_SERVER['QUERY_STRING']query string(查询字符串),如果有的话,通过它进行页面访问。
$_SERVER['SERVER_SOFTWARE' ]<🎜>요청에 응답할 때 서버 식별 문자열 헤더 정보에 나와 있습니다. (예: Apache/2.2.24)<🎜><🎜><🎜>$_SERVER['SERVER_PROTOCOL']<🎜><🎜>페이지 요청 시 통신 프로토콜의 이름과 버전입니다. 예를 들어 "HTTP/1.0"입니다. <🎜><🎜><🎜>$_SERVER['REQUEST_METHOD']<🎜><🎜>페이지에 액세스하는 데 사용되는 요청 방법(예: "GET", "HEAD", "POST", ") 놓다". <🎜><🎜><🎜><🎜>
<🎜><🎜>$_SERVER['REQUEST_TIME']<🎜><🎜><🎜>요청이 시작된 타임스탬프입니다. PHP 5.1.0부터 사용 가능합니다. (예: 1377687496)<🎜><🎜><🎜>$_SERVER['QUERY_STRING']<🎜><🎜>쿼리 문자열(query string)이 있는 경우 이를 통해 페이지 액세스를 수행합니다. <🎜><🎜><🎜><🎜>
$_SERVER['HTTP_ACCEPT']当前请求头中 Accept: 项的内容,如果存在的话。
$_SERVER['HTTP_ACCEPT_CHARSET']当前请求头中 Accept-Charset: 项的内容,如果存在的话。例如:"iso-8859-1,*,utf-8"。
$_SERVER['HTTP_HOST']当前请求头中 Host: 项的内容,如果存在的话。




$_SERVER['HTTP_REFERER'

引导用户代理到当前页的前一页的地址(如果存在)。由 user agent 设置决定。并不是所有的用户代理都会设置该项,有的还提供了修改 HTTP_REFERER 的功能。简言之,该值并不可信。)
$_SERVER['HTTPS']如果脚本是通过 HTTPS 协议被访问,则被设为一个非空的值
$_SERVER['REMOTE_ADDR']浏览当前页面的用户的 IP 地址。


$_SERVER['REMOTE_HOST']

浏览当前页面的用户的主机名。DNS 反向解析不依赖于用户的 REMOTE_ADDR。
$_SERVER['REMOTE_PORT']用户机器上连接到 Web 服务器所使用的端口号。



$_SERVER['SERVER_ADMIN']

该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。(如:someone@php.cn)



$_SERVER['SERVER_PORT']

Web 服务器使用的端口。默认值为 "80"。如果使用 SSL 安全连接,则这个值为用户设置的 HTTP 端口。
$_SERVER['SERVER_SIGNATURE']包含了服务器版本和虚拟主机名的字符串。


$_SERVER['PATH_TRANSLATED']

当前脚本所在文件系统(非文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。



$_SERVER['SCRIPT_NAME']

包含当前脚本的路径。这在页面需要指向自己时非常有用。__FILE__ 常量包含当前脚本(例如包含文件)的完整路径和文件名。

PHP $_REQUEST

PHP $_REQUEST는 HTML로 제출된 데이터를 수집하는 데 사용됩니다. 양식.

예제

다음 예는 입력 필드(입력)와 제출 버튼(제출)을 보여줍니다. 형태. 사용자가 "제출" 버튼을 클릭하여 양식 데이터를 제출하면 양식 데이터가 <form> 태그의 작업 속성에 지정된 스크립트 파일로 전송됩니다. 이 예에서는 양식 데이터를 처리할 파일을 지정합니다. 다른 PHP 파일이 이 데이터를 처리하도록 하려면 지정된 스크립트 파일 이름을 수정할 수 있습니다. 그런 다음 슈퍼 전역 변수 $_REQUEST를 사용하여 다음 형식의 입력 필드 데이터를 수집할 수 있습니다.

<html>
 <body>
 
 <form method="post" action="<?php echo $_SERVER['PHP_SELF'];?>">
     Name: <input type="text" name="fname">
     <input type="submit">
 </form>
 
 <?php
 $name = $_REQUEST['fname'];
 echo $name;
 ?>
 
 </body>
 </html>

프로그램을 실행하고 확인하세요.

입력창에 데이터를 입력하고 쿼리 제출

: action: 특정 파일에 제출되도록 지정할 수 있으며, 예를 들어 action="app.php", 위의

예시는 PHP 파일을 생성하고 싶지 않기 때문에 이 단락<?php echo

$_SERVER['PHP_SELF'];?>는 자신의 페이지에 제출하는 것을 의미합니다.


PHP $_POST

$_POST 변수는 method="post"를 사용하여 양식에서 값을 수집하는 데 사용됩니다.


Instance

수퍼 전역 변수 $ 사용 _POST는 양식 입력 필드 데이터에서 데이터를 수집합니다:

<html>
 <body>
 <form method="post" action="<?php echo $_SERVER['PHP_SELF'];?>">
     Name: <input type="text" name="name">
     Age  :<input type="text" name="age">
     <input type="submit">
 </form>
 <?php
 $name = $_POST['name'];
 $age=$_POST['age'];
 echo $name ."<br/>";
 echo $age;
 ?>
 
 </body>
 </html>


PHP $_GET

PHP $_GET은 양식 데이터를 수집하는 데에도 널리 사용됩니다. HTML 양식 태그에 이 속성을 지정합니다: "method="get".

GET 방식으로 양식에서 전송된 정보는 누구나 볼 수 있으며(브라우저의 주소 표시줄에 표시됨) 전송되는 정보의 양에는 제한이 있습니다(최대 100개

자). 슈퍼 전역 변수 $_GET을 사용하여 다음 형식의 입력 필드 데이터를 수집합니다.

<html>
 <body>
 <form method="get" action="<?php echo $_SERVER['PHP_SELF'];?>">
     Name: <input type="text" name="name">
     Age  :<input type="text" name="age">
     <input type="submit">
 </form>
 <?php
 $name = $_GET['name'];
 $age=$_GET['age'];
 echo $name ."<br/>";
 echo $age;
 ?>
 
 </body>
 </html>

프로그램 실행 결과: : $_POST 및 $_GET에 대해 자세히 알아보려면 PHP 양식 장을 방문하세요.

지속적인 학습
||
<?php $x = 75; $y = 25; function addition() { $GLOBALS['z'] = $GLOBALS['x'] + $GLOBALS['y']; } addition(); echo $z; ?>
  • 코스 추천
  • 코스웨어 다운로드
현재 코스웨어를 다운로드할 수 없습니다. 현재 직원들이 정리하고 있습니다. 앞으로도 본 강좌에 많은 관심 부탁드립니다~