PHP $_SERVER 超全局变量--【聚合篇】
发布日期:2021-06-29 17:05:12 浏览次数:2 分类:技术文章

本文共 8670 字,大约阅读时间需要 28 分钟。

相信很多同学在PHP开发的过程中都见过$_SERVER,相信很多同学都很疑惑$_SERVER到底是什么呢,其实它就是一个数组,而$_SERVER这个数组中包含的东西可多了,那么我们本篇文章就来详细的讲一下PHP中的$_SERVER数组里包含的到底是什么

$_SERVER['HTTP_ACCEPT_LANGUAGE'];//浏览器语言 $_SERVER['REMOTE_ADDR']; //当前用户 IP 。 $_SERVER['REMOTE_HOST']; //当前用户主机名 $_SERVER['REQUEST_URI']; //URL$_SERVER['REMOTE_PORT']; //端口。 $_SERVER['SERVER_NAME']; //服务器主机的名称。 $_SERVER['PHP_SELF'];//正在执行脚本的文件名 $_SERVER['argv']; //传递给该脚本的参数。 $_SERVER['argc']; //传递给程序的命令行参数的个数。 $_SERVER['GATEWAY_INTERFACE'];//CGI 规范的版本。 $_SERVER['SERVER_SOFTWARE']; //服务器标识的字串 $_SERVER['SERVER_PROTOCOL']; //请求页面时通信协议的名称和版本 $_SERVER['REQUEST_METHOD'];//访问页面时的请求方法 $_SERVER['QUERY_STRING']; //查询(query)的字符串。$_SERVER['DOCUMENT_ROOT']; //当前运行脚本所在的文档根目录 $_SERVER['HTTP_ACCEPT']; //当前请求的 Accept: 头部的内容。 $_SERVER['HTTP_ACCEPT_CHARSET']; //当前请求的 Accept-Charset: 头部的内容。 $_SERVER['HTTP_ACCEPT_ENCODING']; //当前请求的 Accept-Encoding: 头部的内容 $_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['SCRIPT_FILENAME']; //当前执行脚本的绝对路径名。 $_SERVER['SERVER_ADMIN']; //管理员信息 $_SERVER['SERVER_PORT']; //服务器所使用的端口 $_SERVER['SERVER_SIGNATURE']; //包含服务器版本和虚拟主机名的字符串。 $_SERVER['PATH_TRANSLATED']; //当前脚本所在文件系统(不是文档根目录)的基本路径。 $_SERVER['SCRIPT_NAME']; //包含当前脚本的路径。这在页面需要指向自己时非常有用。 $_SERVER['PHP_AUTH_USER']; //当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。 $_SERVER['PHP_AUTH_PW']; //当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。 $_SERVER['AUTH_TYPE']; //当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型

我们可以将$_SERVER当成普通数组一样,去修改它等操作。


两种PHP获取服务器端IP地址的方法

PHP获取服务器IP地址方法一:

if ('/' == DIRECTORY_SEPARATOR) {    $server_ip = $_SERVER['SERVER_ADDR'];} else {    $server_ip = @gethostbyname($_SERVER['SERVER_NAME']);}echo $server_ip;

php获取服务器ip地址方法二:

/** * 获取服务器端IP地址 * @return string */ function get_server_ip(){    if (isset($_SERVER)) {        if ($_SERVER['SERVER_ADDR']) {            $server_ip = $_SERVER['SERVER_ADDR'];        } else {            $server_ip = $_SERVER['LOCAL_ADDR'];        }    } else {        $server_ip = getenv('SERVER_ADDR');    }    return $server_ip;} echo get_server_ip();

PHP中的$_SERVER并不复杂,仔细去看就这么点东西,PHP中的$_SERVER数组是一个包含服务器和执行环境信息的数组。

以上转自:


PHP超全局变量$_SERVER

 $_SERVER 是一个包含了诸如头信息(header)、路径(path)、以及脚本位置(script locations)等等信息的数组。这个数组中的项目由 Web 服务器创建。不能保证每个服务器都提供全部项目;服务器可能会忽略一些,或者提供一些没有在这里列举出来的项目。

  1. $_SERVER['HTTP_HOST']  请求头信息中的Host内容,获取当前域名。
  2. $_SERVER["SERVER_NAME"]  输出配置文件httpd.conf中的ServerName,一般情况下与HTTP_HOST值相同,但如果服务器端口不是默认的80端口,或者协议规范不是HTTP/1.1时,HTTP_HOST会包含这些信息,而SERVER_NAME不一定包含。(主要看配置文件的设置)。
  3. $_SERVER["HTTP_USER_AGENT"]  获取用户相关信息,包括用户浏览器、操作系统等信息。
  4. $_SERVER['HTTP_ACCEPT']  当前请求的ACCEPT头部信息。
  5. $_SERVER["HTTP_ACCEPT_LANGUAGE"]  这个值是由浏览器发送,表明用户默认的语言设置,后面的q值表示用户对该语言的喜好程度。
  6. $_SERVER["HTTP_ACCEPT_ENCODING"]  大部分的现代浏览器都支持gzip压缩,并会把这一信息报告给服务器。这时服务器就会压缩过的HTML发送给浏览器。这可以减少近80%的文件大小,以节省下载时间和带宽。
  7. $_SERVER["HTTP_COOKIE"]  浏览器的cookie信息。
  8. $_SERVER["HTTP_CONNECTION"]  当前请求的连接情况。
  9. $_SERVER["HTTP_UPGRADE_INSECURE_REQUESTS"]  表示浏览器可读懂服务器发过来的请求,
  10. $_SERVER["HTTP_CACHE_CONTROL"]  表示浏览器是否会缓存这个页面信息。
  11. $_SERVER["PATH"]  当前脚本所在文件系统。
  12. $_SERVER["SystemRoot"]  当前服务器的操作系统。
  13. $_SERVER["COMSPEC"]  指向cmd.exe的路径。
  14. $_SERVER["PATHEXT"]  环境变量设置。
  15. $_SERVER["WINDIR"]  脚本指向的系统目录。
  16. $_SERVER["SERVER_SIGNATURE"]  包含服务器版本和虚拟主机名的字符串。
  17. $_SERVER["SERVER_SOFTWARE"]  服务器软件配置信息。
  18. $_SERVER["SERVER_ADDR"]  当前运行脚本的服务器的ip地址。
  19. $_SERVER["SERVER_PORT"]  服务器端口。
  20. $_SERVER["REMOTE_ADDR"]  浏览网页的用户ip。
  21. $_SERVER["DOCUMENT_ROOT"]  当前运行脚本所在的根目录。
  22. $_SERVER["REQUEST_SCHEME"]  服务器通信协议,是http或https。
  23. $_SERVER["CONTEXT_PREFIX"]  前缀。
  24. $_SERVER["CONTEXT_DOCUMENT_ROOT"]  当前脚本所在的文档根目录。
  25. $_SERVER["SERVER_ADMIN"]  服务器管理员信息。
  26. $_SERVER["SCRIPT_FILENAME"]  当前执行脚本的绝对路径。
  27. $_SERVER ["REMOTE_PORT"]  用户连接到服务器时所使用的端口。
  28. $_SERVER["GATEWAY_INTERFACE"]  服务器使用的CGI规范的版本。
  29. $_SERVER["SERVER_PROTOCOL"]  请求页面时通信协议的名称和版本。
  30. $_SERVER["REQUEST_METHOD"]  请求提交数据的方式。
  31. $_SERVER["QUERY_STRING"]  服务器请求时?后面的参数。
  32. $_SERVER["REQUEST_URI"]  当前脚本路径,根目录之后的目录。
  33. $_SERVER["SCRIPT_NAME"]  当前脚本的路径。这在页面需要指向自己时非常有用。
  34. $_SERVER["PHP_SELF"]  当前正在执行脚本的文件名。
  35. $_SERVER["REQUEST_TIME"]  得到请求开始时的时间戳。
  36.  

以上转自: 


PHP中$_SERVER的详细用法

$_SERVER['PHP_SELF'] #当前正在执行脚本的文件名,与 document root相关。$_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”。$_SERVER['PHP_AUTH_USER'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。$_SERVER['PHP_AUTH_PW'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。$_SERVER['AUTH_TYPE'] #当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型。$_SERVER[”HTTP_X_FORWARDED_FOR”] #透过代理服务器取得客户端的真实 IP 地址$_SERVER['HTTP_VIA'] #代理服务器IP$_SERVER['HTTP_CLIENT_IP'] #客户端IP

服务器变量:$_SERVER

注: 在 PHP 4.1.0 及以后版本使用。之前的版本,使用 $HTTP_SERVER_VARS。

$_SERVER 是一个包含诸如头部(headers)、路径(paths)和脚本位置(script locations)的数组。数

组的实体由 web 服务器创建。不能保证所有的服务器都能产生所有的信息;服务器可能忽略了一些
信息,或者产生了一些未在下面列出的新的信息。这意味着,大量的这些变量在 CGI 1.1
specification 中说明,所以您应该仔细研究它。

这是一个“superglobal”,或者可以描述为自动全局变量。这只不过意味这它在所有的脚本中都有

效。在函数或方法中您不需要使用 global $_SERVER; 访问它,就如同使用 $HTTP_SERVER_VARS 一
样。

$HTTP_SERVER_VARS 包含着同样的信息,但是不是一个自动全局变量。(注意: $HTTP_SERVER_VARS

和 $_SERVER 是不同的变量,PHP 处理它们的方式不同。)

如果设置了 register_globals 指令,这些变量也在所有脚本中可用;也就是,分离了 $_SERVER 和

$HTTP_SERVER_VARS 数组。相关信息,请参阅安全的相关章节 使用 Register Globals。这些单独的
全局变量不是自动全局变量。

您或许会发现下面列出的某些 $_SERVER 元素并不可用。注意,如果以命令行方式运行 PHP,下面列

出的元素几乎没有有效的(或是没有任何实际意义的)。

“PHP_SELF”

当前正在执行脚本的文件名,与 document root相关。举例来说,在URL地址为
http://easyboor.com/test.php/foo.bar 的脚本中使用 $_SERVER['PHP_SELF'] 将会得到
/test.php/foo.bar 这个结果。

如果 PHP 以命令行方式运行,该变量无效。

“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”。

“QUERY_STRING”

查询(query)的字符串。

“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() 得到这个
信息。

“REMOTE_ADDR”

正在浏览当前页面用户的 IP 地址。

'REMOTE_HOST'

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

注: 必须配置 Web 服务器来建立此变量。例如 Apache 需要在 httpd.conf 中有 HostnameLookups

On。参见 gethostbyaddr()。

“REMOTE_PORT”

用户连接到服务器时所使用的端口。

“SCRIPT_FILENAME”

当前执行脚本的绝对路径名。

“SERVER_ADMIN”

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

“SERVER_PORT”

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

“SERVER_SIGNATURE”

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

“PATH_TRANSLATED”

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

“SCRIPT_NAME”

包含当前脚本的路径。这在页面需要指向自己时非常有用。

“REQUEST_URI”

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

“PHP_AUTH_USER”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户
名。

“PHP_AUTH_PW”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码

“AUTH_TYPE”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型。

转自:

转载地址:https://cplvfx.blog.csdn.net/article/details/103612136 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:最新版 安全狗设置
下一篇:asp 断点测试,异常打印

发表评论

最新留言

留言是一种美德,欢迎回访!
[***.207.175.100]2024年04月17日 17时47分44秒