欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP $_SERVER超全局变量详解

程序员文章站 2022-06-24 14:07:09
参考资料:https://www.php.net/manual/zh/reserved.variables.server.php $_SERVER 是一个包含了诸如头信息(header)、路径(path)、以及脚本位置(script locations)等等信息的数组。这个数组中的项目由 Web 服 ......

参考资料:

 

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

 

  1. $_server['gateway_interface']—— 服务器使用的 cgi 规范的版本;例如,“cgi/1.1”。
  2. $_server['server_addr']—— 当前运行脚本所在的服务器的 ip 地址。
  3. $_server['server_name'] ——当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定。$_server['server_software'] 
    • note: 在 apache 2 里,必须设置 usecanonicalname = on 和 servername。 否则该值会由客户端提供,就有可能被伪造。 上下文有安全性要求的环境里,不应该依赖此值。
  4. $-server['server_software']——服务器标识字符串,在响应请求时的头信息中给出。
  5. $_server['server_protocol']——请求页面时通信协议的名字和版本。例如,'http/1.0'
  6. $_server['request_method']—— 访问页面使用的请求方法。例如,'post','get'$_server['']
    • note:如果请求方法为 head,php 脚本将在发送 header 头信息之后终止(这意味着在产生任何输出后,不再有输出缓冲)。
  7. $_server['request_time']——请求开始的时间戳,从 php 5.1.0 起可用。
  8. $_server['request_time_float']——请求开始饿时间戳,微秒级别的精准度。自 php 5.4.0 开始生效。
  9. $_server['query_string']——query_string(查询字符串)如果有的话,通过它进行页面访问。
  10. $_server['document_root']——当前运行脚本所在的文档目录根目录。在服务器配置文件中定义。
  11. $_server['http_accept']——当前请求头中accept:项的内容,如果存在的话。
  12. $_server['http_accept_charset']——当前请求头中accept-charset:项中的内容,如果 有的话。例如,"iso-8859-1,*,utf-8".
  13. $_server['http_accept_encoding']——当前请求头中accept-encoding:项中的内容,如果有的话。例如,"gzip"。
  14. $_server['http_accept_language']——当前请求头中accept-language:项中的内容,如果有的话。例如,"en"
  15. $_server['http_connection']——当前请求头中connection:项中的内容,如果存在的话。例如,"keep-alive"
  16. $_server['hhtp_host']——当前请求头中host:项中的内容,如果存在的话。
  17. $_server['http_referer']——引导用户代理到当前页的前一页的地址(如果存在)。由 user agent 设置决定。并不是所有的用户代理都会设置该项,有的还提供了修改 http_referer 的功能。简言之,该值并不可信。
  18. $_server['http_user_agent']——当前请求头中user-agent:项中的内容,如果存在的话。该字符串表明了访问该页面的用户代理的信息。一个典型的例子是:mozilla/4.5 [en] (x11; u; linux 2.2.9 i586)。除此之外,你可以通过  来使用该值,从而定制页面输出以便适应用户代理的性能。 
  19. $_server['https']——如果脚本是通过https访问的,则被设为一个非空的值。
    • note: 注意当使用 iis 上的 isapi 方式时,如果不是通过 https 协议被访问,这个值将为 off。
  20. $_server['remote_addr']——浏览当前页面的用户的ip地址。
  21. $_server['remote_host']——浏览当前页面的用户的主机名。dns反向解析不依赖于用户的remote_addr
    • note: 你的服务器必须被配置以便产生这个变量。例如在 apache 中,你需要在 httpd.conf 中设置 hostnamelookups on 来产生它。
  22. $_server['remote_port']——用户机器上连到web服务器所使用的端口。
  23. $_server['remote_user']——经验证的用户
  24. $_server['redirect_remote_user']——验证的用户,如果请求已在内部重定向。
  25. $_server['script_filename']——当前执行脚本的绝对路径
  26. $_server['server_admin']——该值指明了apache服务器配置文件中的server_admin参数。如果脚本执行在一个虚拟主机上,则该值是那个虚拟主机的值。
  27. $_server['server_port']——web服务器使用的端口。默认值为“80”。如果使用了ssl安全连接,则这个值为用户设置的http的端口。
    • note: 在 apache 2 里,为了获取真实物理端口,必须设置 usecanonicalname = on 以及 usecanonicalphysicalport = on。 否则此值可能被伪造,不一定会返回真实端口值。 上下文有安全性要求的环境里,不应该依赖此值。
  28. $_server['server_signature']——包含了服务器版本和虚拟主机名的字符串。
  29. $_server['server_translated']——当前脚本在文件系统(非文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。
  30. $_server['script_name']——包含当前脚本的当前路径。
  31. $_server['request_url']——url用来指定要访问的页面。
  32. $_server['php_auth_digest']——当作为 apache 模块运行时,进行 http digest 认证的过程中,此变量被设置成客户端发送的“authorization” http 头内容(以便作进一步的认证操作)。
  33. $_server['php_auth_user']——当 php 运行在 apache 或 iis(php 5 是 isapi)模块方式下,并且正在使用 http 认证功能,这个变量便是用户输入的用户名。
  34. $_server['php_auth_pw']——当 php 运行在 apache 或 iis(php 5 是 isapi)模块方式下,并且正在使用 http 认证功能,这个变量便是用户输入的密码。
  35. $_server['auth_type']——当 php 运行在 apache 模块方式下,并且正在使用 http 认证功能,这个变量便是认证的类型。
  36. $_server['path_info']——包含由客户端提供的、跟在真实脚本名称之后并且在查询语句(query string)之前的路径信息,如果存在的话。例如,如果当前脚本是通过 url http://www.example.com/php/path_info.php/some/stuff?foo=bar被访问,那么 $_server['path_info'] 将包含 /some/stuff。
  37. $_server['orig_path_info']——在被 php 处理之前,“path_info” 的原始版本。