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가 명령줄 모드에서 실행 중인 경우 이 변수에는 스크립트 이름이 포함됩니다. 이 변수는 이전 버전에서는 사용할 수 없습니다. | 서버에서 사용하는 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['REQUEST_TIME']<🎜><🎜><🎜>요청이 시작된 타임스탬프입니다. PHP 5.1.0부터 사용 가능합니다. (예: 1377687496)<🎜><🎜>
$_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 양식 장을 방문하세요.
- 코스 추천
- 코스웨어 다운로드
-
초등학교Imperial CMS 기업 모방 웹사이트 튜토리얼
3048명이 시청하고 있습니다. -
초등학교WordPress에 기초가 전혀 없는 초보자는 개인 블로그와 기업 웹 사이트를 구축합니다.
6743명이 시청하고 있습니다. -
초등학교궁극의 CMS 제로 기반 웹사이트 구축 지침 영상
2724명이 시청하고 있습니다. -
초등학교프론트엔드 프로젝트 - Shangyou [HTML/CSS/JS 기술 종합실습]
3117명이 시청하고 있습니다. -
중급Vue3.0 from 0을 통해 범용 백엔드 관리 시스템 프로젝트 실습 구축
5351명이 시청하고 있습니다. -
초등학교제로 기반 프론트엔드 과정 [Vue 고급 학습 및 실무 적용]
2821명이 시청하고 있습니다. -
초등학교웹 프론트엔드 튜토리얼 [HTML5+CSS3+JS]
3506명이 시청하고 있습니다. -
초등학교apipost에 대한 빠른 소개
2161명이 시청하고 있습니다. -
중급Vue3+TypeScript 실무 튜토리얼-엔터프라이즈 수준 프로젝트 실습
3208명이 시청하고 있습니다. -
초등학교PHP로 사업을 시작하는 방법에 대해 간단히 이야기해 보겠습니다.
17423명이 시청하고 있습니다. -
중급VUE 전자상거래 프로젝트(프론트엔드 & 백엔드 듀얼 프로젝트 실전)
3828명이 시청하고 있습니다. -
초등학교Apipost 실무 응용 [api, 인터페이스, 자동화 테스트, 모의]
2265명이 시청하고 있습니다.
이 강좌를 시청한 학생들도 학습하고 있습니다.
- PHP로 사업을 시작하는 방법에 대해 간단히 이야기해 보겠습니다.
- 웹 프론트 엔드 개발에 대한 빠른 소개
- 민망한 물건 백과사전 사이트를 모방한 Mini 버전 MVC 프레임워크의 대규모 실용 Tianlongbabu 개발
- PHP 실용 개발 시작하기: 빠른 PHP 생성 [중소기업 포럼]
- 로그인 인증 및 클래식 게시판
- 컴퓨터 네트워크 지식 수집
- 빠른 시작 Node.JS 정식 버전
- 당신을 가장 잘 이해하는 프론트엔드 강좌: HTML5/CSS3/ES6/NPM/Vue/...[원본]
- 자신만의 PHP MVC 프레임워크 작성(깊이 있는 40개 장/자세한 내용/초보자가 발전하려면 읽어야 함)