PHP 第3章 预定义超全局变量 PHP 第3章 预定义超全局变量

2019-08-24

一、什么是全局变量

  • 全局变量是定义在所有函数以外的变量,其作用域是整个 php 文件,但是在用户自定义的函数内部是无法使用的。

  • 如果一定要在用户自定义的函数内部使用全局变量,那么就需要使用 global 关键字声明。

  • 也就是说如果在函数内的变量前加上 golbal 来修饰,那么函数内部就可以访问到这个全局变量, 不仅可以利用这个全局变量进行运算而且可以对这个全局变量进行重新赋值。

二、内置全局变量

2.1、$_GET

①、全局变量和超全局变量

(1)全局变量:变量作用于整个作用域,如 global $a

(2)超全局变量:除了有全局变量的特点外,还无须声明,直接使用

②、get 方式提交数据的形式

(1)超链接默认用 get 方式提交

(2)表单也可以用 gte 方式提交

(3)header("Location:ok.php?username=lulubin");

③、IE 5.5 和 IE 6.0 中文奇数乱码的解决方案

(1)方案一

A 给奇数中文加一个全角空格:city = 北京好(全角空格)

B 在服务器接收数据的时候去掉两边的空格:strim(print_r($_GET))

(2)方案二

A 使用 urlencode( )  编码 url 字符串

B 使用 urldecode( ) 解码已编码的 url 字符串

④、判断 $_GET 是否收到值

(1)empty($_GET['city']) —— 建议使用

(2)!isset($_GET['city'])

2.2、$_POST

①、基本概念

(1)通过 http post 方式提交的数据,会被封装到 $_POST

(2)浏览器通过表单传送信息给服务器并且需要用 post 方式,有些数据的提交比较用 post ,如上传文件

②、使用细节

(1)复选框 checkbox 的提交 name = "hobby[ ]",要加中括号变成数组,否则只会提交选中的最后一个

(2)get 和 post 的区别

A 安全性:get请求的数据会显示在地址栏上,post请求的数据放在http协议的消息体

B 从可以提交的数据大小看:http协议本身并没有限制数据大小,浏览器对get限制,get请求数据2K+35

C get请求可以更好的添加到收藏栏(由于收藏夹收藏地址栏)

2.3、$_REQUEST

①、定义

(1)$_REQUEST 默认情况下包含 $_GET、$_POST、$_COOKIE 的数组

(2)由于 $_REQUEST 中的变量 GTE、POST、COOKIE 输入机制传递给脚本文件,因此可以被远程用户篡改而不可信

②、不用经常使用 $_REQUEST,若不确定用 $_GET 还是 $_POST,你可以这样接收数据:

if ($_SERVER["REUQEST_METHOD"] == "POST") {
     //用 $_POST 接收
}else if ($_SERVER["REUQEST_METHOD"] == "GET") {
     //用 $_GET 接收
}

2.4、$_SERVER

①、定义

$_SERVER 主要包含 http 请求行和消息头的信息,同时还有服务器自己的一些信息,比如 DOCUMENT_ROOT

②、详细参数

PHP编程中经常需要用到一些服务器的一些资料,特把$_SERVER的详细参数整理下,方便以后使用。
$_SERVER["PHP_SELF"] #当前正在执行脚本的文件名,与 document root相关。
__FILE__ 文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。 
自PHP 4.0.2 起, __FILE__总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径), 而在此之前的版本有时会包含一个相对路径。
$_SERVER["argv"] #传递给该脚本的参数。
$_SERVER["argc"] #包含传递给程序的命令行参数的个数(如果运行在命令行模式)。
$_SERVER["GATEWAY_INTERFACE"] #服务器使用的 CGI 规范的版本。例如,“CGI/1.1”。
$_SERVER["SERVER_NAME"] #当前运行脚本所在服务器主机的名称。
$_SERVER["SERVER_SOFTWARE"] #服务器标识的字串,在响应请求时的头部中给出。
$_SERVER["SERVER_PROTOCOL"] #请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。
$_SERVER["REQUEST_METHOD"] #访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。
$_SERVER["QUERY_STRING"] #查询(query)的字符串。
$_SERVER["DOCUMENT_ROOT"] #当前运行脚本所在的文档根目录。在服务器配置文件中定义。
$_SERVER["HTTP_ACCEPT"] #当前请求的 Accept: 头部的内容。
$_SERVER["HTTP_ACCEPT_CHARSET"] #当前请求的 Accept-Charset: 头部的内容。例如:“iso-8859-1,*,utf-8”。
$_SERVER["HTTP_ACCEPT_ENCODING"] #当前请求的 Accept-Encoding: 头部的内容。例如:“gzip”。
$_SERVER["HTTP_ACCEPT_LANGUAGE"]#当前请求的 Accept-Language: 头部的内容。例如:“en”。
$_SERVER["HTTP_CONNECTION"] #当前请求的 Connection: 头部的内容。例如:“Keep-Alive”。
$_SERVER["HTTP_HOST"] #当前请求的 Host: 头部的内容。
$_SERVER["HTTP_REFERER"] #链接到当前页面的前一页面的 URL 地址。
$_SERVER["HTTP_USER_AGENT"] #当前请求的 User-Agent: 头部的内容。
$_SERVER["HTTPS"] — 如果通过https访问,则被设为一个非空的值(on),否则返回off
$_SERVER["REMOTE_ADDR"] #正在浏览当前页面用户的 IP 地址。
$_SERVER["REMOTE_HOST"] #正在浏览当前页面用户的主机名。
$_SERVER["REMOTE_PORT"] #用户连接到服务器时所使用的端口。
$_SERVER["SCRIPT_FILENAME"] #当前执行脚本的绝对路径名。
$_SERVER["SERVER_ADMIN"] #管理员信息
$_SERVER["SERVER_PORT"] #服务器所使用的端口
$_SERVER["SERVER_SIGNATURE"] #包含服务器版本和虚拟主机名的字符串。
$_SERVER["PATH_TRANSLATED"] #当前脚本所在文件系统(不是文档根目录)的基本路径。
$_SERVER["SCRIPT_NAME"] #包含当前脚本的路径。这在页面需要指向自己时非常有用。
$_SERVER["REQUEST_URI"] #访问此页面所需的 URI。例如,“/index.html”。

打印服务器IP:echo gethostbyname("www.lulublog.cn");

2.5、$_ENV

①、定义

$_ENV 是 PHP 中的一个包含服务器端环境变量的数组

②、细节说明

(1) 由于$_ENV变量是取决于服务器的环境变量的,从不同的服务器上获取的$_ENV变量打印出的结果可能是完全不同的。所以无法像$_SERVER 那样列出完整的列表。

(2)EGPCS

A 以下是$_ENV 数组包含的比较通用的元素:

有时候,$_ENV会为空,其原因通常是php的配置文件php.ini的配置项为:variables_order = "GPCS"。

要想让$_ENV的值不为空,那么variables_order的值应该加上一个大写字母“E”,即:variables_order = "EGPCS"。

B 上述配置表示了PHP接受的外部变量来源及顺序,EGPCS是Environment、Get、Post、Cookies、Server的缩写。

如果variables_order 的配置中缺少E ,则PHP 无法接受环境变量,那么$_ENV 也就为空了。

C 由于开启$_ENV,即 variables_order = "EGPCS" 会导致一些性能损失,按 php 官方的说法是,在生产环境中,不推荐使用。他们更推荐使用 getenv (string $varname) 函数来获取 Environment 中的值,而这点需要在编程时就注意到。如果编程时用了 $_ENV 而 variables_order 中又没有配置为 variables_order = "EGPCS" ,则程序运行时可能会报错。

③、getenv( )

有时候,$_ENV 会为空,其原因通常是php的配置文件 php.ini 的配置项为:variables_order = "GPCS"。要想让 $_ENV 的值不为空,那么 variables_order 的值应该加上一个大写字母“E”,即:variables_order = "EGPCS"。所以,官方建议用 getenv 函数。

getenv()函数定义:取得系统的环境变量; 
语法:string getenv(string varname); 
注:返回的是字符串;

在 PHP 中 getenv(参数) 函数是一个用于获取环境变量的函数,根据提供不同的参数可以获取不同的环境变量。

  • “PHP_SELF”:当前正在执行脚本的文件名,与document root 相关。 如果PHP 以命令行方式运行,该变量在PHP 4.3.0 之前无效。

  • “argv”:传递给该脚本的参数。当脚本运行在命令行方式时,argv 变量传递给程序C 语言样式的命令行参数。当调用GET 方法时,该变量包含请求的数据。

  • “argc” 包含传递给程序的命令行参数的个数(如果运行在命令行模式)。

  • “GATEWAY_INTERFACE” 服务器使用的CGI 规范的版本。例如,“CGI/1.1”。

  • “SERVER_NAME”当前运行脚本所在服务器主机的名称。如果该脚本运行在一个虚拟主机上,该名称是由那个虚拟主机所设置的值决定。

  • “SERVER_SOFTWARE” 服务器标识的字串,在响应请求时的头信息中给出。

  • “SERVER_PROTOCOL” 请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。

  • “REQUEST_METHOD” 访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。 

  • 注: 如果请求的方式是HEAD,PHP 脚本将在送出头信息后中止(这意味着在产生任何输出后,不再有输出缓冲)。

  • “REQUEST_TIME” 请求开始时的时间戳。从PHP 5.1.0 起有效。

  • “QUERY_STRING” 查询(query)的字符串(URL 中第一个问号? 之后的内容)。

  • “DOCUMENT_ROOT” 当前运行脚本所在的文档根目录。在服务器配置文件中定义。

  • “HTTP_ACCEPT” 当前请求的Accept: 头信息的内容。

  • “HTTP_ACCEPT_CHARSET” 当前请求的Accept-Charset: 头信息的内容。例如:“iso-8859-1,*,utf-8”。

  • “HTTP_ACCEPT_ENCODING” 当前请求的Accept-Encoding: 头信息的内容。例如:“gzip”。

  • “HTTP_ACCEPT_LANGUAGE” 当前请求的Accept-Language: 头信息的内容。例如:“en”。

  • “HTTP_CONNECTION” 当前请求的Connection: 头信息的内容。例如:“Keep-Alive”。

  • “HTTP_HOST” 当前请求的Host: 头信息的内容。

  • “HTTP_REFERER” 链接到当前页面的前一页面的URL地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改HTTP_REFERER。因此,这个变量不总是真实正确的。

  • “HTTP_USER_AGENT” 当前请求的User-Agent: 头信息的内容。该字符串表明了访问该页面的用户代理的信息。一个典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。也可以使用get_browser() 得到此信息。

  • “HTTPS” 如果脚本是通过HTTPS 协议被访问,则被设为一个非空的值。

  • “REMOTE_ADDR” 正在浏览当前页面用户的IP 地址。

  • “REMOTE_HOST” 正在浏览当前页面用户的主机名。反向域名解析基于该用户的 

  • REMOTE_ADDR。 注: 必须配置Web 服务器来建立此变量。例如Apache 需要在httpd.conf 中有HostnameLookups On。参见gethostbyaddr()。

  • “REMOTE_PORT” 用户连接到服务器时所使用的端口。

  • “SCRIPT_FILENAME” 当前执行脚本的绝对路径名。 注: 如果脚本在CLI 中被执行,作为相对路径,例如file.php 或../file.php,$_SERVER[‘SCRIPT_FILENAME’] 将包含用户指定的相对路径。

  • “SERVER_ADMIN” 该值指明了Apache 服务器配置文件中的SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。

  • “SERVER_PORT” 服务器所使用的端口。默认为“80”。如果使用SSL 安全连接,则这个值为用户设置的HTTP 端口。

  • “SERVER_SIGNATURE” 包含服务器版本和虚拟主机名的字符串。

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

  • 注: PHP 4.3.2 之后,PATH_TRANSLATED 在Apache 2 SAPI 模式下不再和Apache 1 一样隐含赋值,而是若Apache 不生成此值,PHP 便自己生成并将其值放入SCRIPT_FILENAME 服务器常量中。这个修改遵守了CGI 规范,PATH_TRANSLATED 仅在PATH_INFO 被定义的条件下才存在。 

  • Apache 2 用户可以使用httpd.conf 中的AcceptPathInfo On 来定义PATH_INFO。

  • “SCRIPT_NAME” 包含当前脚本的路径。这在页面需要指向自己时非常有用。FILE 包含当前文件的绝对路径和文件名(例如包含文件)。

  • “REQUEST_URI” 访问此页面所需的URI。例如,“/index.html”。

  • “PHP_AUTH_DIGEST” 当作为Apache 模块运行时,进行HTTP Digest 认证的过程中,此变量被设置成客户端发送的“Authorization”HTTP 头内容(以便作进一步的认证操作)。

  • “PHP_AUTH_USER” 当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的用户名。

  • “PHP_AUTH_PW” 当PHP 运行在Apache 或IIS(PHP 5 是ISAPI)模块方式下,并且正在使用HTTP 认证功能,这个变量便是用户输入的密码。

  • HTTP_CLIENT_IP 取得用户的IP代码;

2.6、$_GLOBAL

①、引用全局作用域中可用的全部变量

②、一个包含了全部变量的全局组合数组,变量的名字就是数组的键

③、自定义的全局变量,也会自动被 $GLOBALS 管理

阅读 2034