<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/reserved.variables.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'zh',
  ),
  'this' => 
  array (
    0 => 'reserved.variables.server.php',
    1 => '$_SERVER',
    2 => '服务器和执行环境信息',
  ),
  'up' => 
  array (
    0 => 'reserved.variables.php',
    1 => '预定义变量',
  ),
  'prev' => 
  array (
    0 => 'reserved.variables.globals.php',
    1 => '$GLOBALS',
  ),
  'next' => 
  array (
    0 => 'reserved.variables.get.php',
    1 => '$_GET',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'zh',
    'path' => 'language/predefined/variables/server.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="reserved.variables.server" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">$_SERVER</h1>
  <p class="refpurpose"><span class="refname">$_SERVER</span> &mdash; <span class="dc-title">服务器和执行环境信息</span></p>

 </div>
 
 <div class="refsect1 description" id="refsect1-reserved.variables.server-description">
  <h3 class="title">说明</h3>
  <p class="para">
   <var class="varname">$_SERVER</var> 是一个包含了诸如头信息（header）、路径（path）、以及脚本位置（script locations）等信息的
   <span class="type"><a href="language.types.array.php" class="type array">array</a></span>。这个数组中的条目由 Web 服务器创建，所以不能保证每个 Web
   服务器都提供全部条目；服务器可能会忽略一些，或者提供此处没有列举出来的其它内容。然而，大部分变量在
   <a href="https://datatracker.ietf.org/doc/html/rfc3875" class="link external">&raquo;&nbsp;CGI 1.1 规范</a>中都有说明，并且很可能会定义。
  </p>
  <blockquote class="note"><p><strong class="note">注意</strong>: 
   <span class="simpara">
    当在<a href="features.commandline.php" class="link">命令行</a>运行 PHP
    时，这些条目都将无效或者没有任何意义。
   </span>
  </p></blockquote>
  <p class="para">
   除了下面列出的元素之外，PHP 还将使用请求报头中的值创建其它元素，这些条目将命名为 <code class="literal">HTTP_</code>
   后跟报头名称，大写且使用下划线而不是连字符。例如 <code class="literal">Accept-Language</code> 报头将作为
   <code class="code">$_SERVER[&#039;HTTP_ACCEPT_LANGUAGE&#039;]</code> 提供。
  </p>
 </div>


 <div class="refsect1 indices" id="refsect1-reserved.variables.server-indices">
  <h3 class="title">目录</h3>

  <p class="para">
   <dl>
    
     <dt>&#039;<var class="varname">PHP_SELF</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当前执行脚本的文件名，与 document root 有关。例如，在地址为 <var class="filename">http://example.com/foo/bar.php</var> 的脚本中使用 <var class="varname">$_SERVER['PHP_SELF']</var> 将得到 <var class="filename">/foo/bar.php</var>。<a href="language.constants.magic.php" class="link">__FILE__</a> 常量包含当前(例如包含)文件的完整路径和文件名。
      </span>
      <span class="simpara">
       如果 PHP 以命令行模式运行，这个变量将包含脚本名。
      </span>
     </dd>
    

    
     <dt>&#039;<a href="reserved.variables.argv.php" class="link">argv</a>&#039;</dt>
     <dd>
      <span class="simpara">
        传递给该脚本的参数的数组。当脚本以命令行方式运行时，argv 变量传递给程序 C 语言样式的命令行参数。当通过 GET 方式调用时，该变量包含query string。
      </span>
     </dd>
    

    
     <dt>&#039;<a href="reserved.variables.argc.php" class="link">argc</a>&#039;</dt>
     <dd>
      <span class="simpara">
       包含命令行模式下传递给该脚本的参数的数目(如果运行在命令行模式下)。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">GATEWAY_INTERFACE</var>&#039;</dt>
     <dd>
      <span class="simpara">
       服务器使用的 CGI 规范的版本；例如，<code class="literal">&#039;CGI/1.1&#039;</code>。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_ADDR</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当前运行脚本所在的服务器的 IP 地址。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_NAME</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中，该名称是由那个虚拟主机所设置的值决定。
      </span>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <span class="simpara">
        在 Apache 2 里，必须设置 <code class="literal">UseCanonicalName = On</code> 和
        <code class="literal">ServerName</code>。否则该值会由客户端提供，就有可能被伪造。上下文有安全性要求的环境里，不应该依赖此值。
       </span>
      </p></blockquote>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_SOFTWARE</var>&#039;</dt>
     <dd>
      <span class="simpara">
       服务器标识字符串，在响应请求时的头信息中给出。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_PROTOCOL</var>&#039;</dt>
     <dd>
      <span class="simpara">
       请求页面时通信协议的名称和版本。例如，<code class="literal">&#039;HTTP/1.0&#039;</code>。
      </span>
     </dd>
    
    
    
     <dt>&#039;<var class="varname">REQUEST_METHOD</var>&#039;</dt>
     <dd>
      <span class="simpara">
       访问页面使用的请求方法；例如，<code class="literal">&#039;GET&#039;</code>、<code class="literal">&#039;HEAD&#039;</code>、<code class="literal">&#039;POST&#039;</code>、<code class="literal">&#039;PUT&#039;</code>。
      </span>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <p class="para">
        如果请求方法为 <code class="literal">HEAD</code>，PHP 脚本将在发送 Header 头信息之后终止(这意味着在产生任何输出后，不再有输出缓冲)。
       </p>
      </p></blockquote>
     </dd>
    

    
     <dt>&#039;<var class="varname">REQUEST_TIME</var>&#039;</dt>
     <dd>
      <span class="simpara">
       PHP 开始处理请求时的时间戳。
      </span>
     </dd>
    
    
    
     <dt>&#039;<var class="varname">REQUEST_TIME_FLOAT</var>&#039;</dt>
     <dd>
      <span class="simpara">
       PHP 开始处理请求时的时间戳，具有微秒精度。
      </span>
     </dd>
    
     
    
     <dt>&#039;<var class="varname">QUERY_STRING</var>&#039;</dt>
     <dd>
      <span class="simpara">
       query string（查询字符串），如果有的话，通过它进行页面访问。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">DOCUMENT_ROOT</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当前运行脚本所在的文档根目录。在服务器配置文件中定义。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">HTTPS</var>&#039;</dt>
     <dd>
      <span class="simpara">
      如果脚本是通过 HTTPS 协议被访问，则被设为一个非空的值。 
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">REMOTE_ADDR</var>&#039;</dt>
     <dd>
      <span class="simpara">
       浏览当前页面的用户的 IP 地址。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">REMOTE_HOST</var>&#039;</dt>
     <dd>
      <span class="simpara">
       浏览当前页面的用户的主机名。DNS 反向解析不依赖于用户的 <var class="varname">REMOTE_ADDR</var>。
      </span>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <span class="simpara">
        必须配置 Web 服务器以创建这个变量。例如在 Apache 中，<code class="literal">HostnameLookups On</code>
        必须在 <var class="filename">httpd.conf</var> 中设置才能存在。参见 <span class="function"><a href="function.gethostbyaddr.php" class="function">gethostbyaddr()</a></span>。
       </span>
      </p></blockquote>
     </dd>
    

    
     <dt>&#039;<var class="varname">REMOTE_PORT</var>&#039;</dt>
     <dd>
      <span class="simpara">
       用户机器上连接到 Web 服务器所使用的端口号。
      </span>
     </dd>
    
    
     <dt>&#039;<var class="varname">REMOTE_USER</var>&#039;</dt>
     <dd>
      <span class="simpara">
        经验证的用户
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">REDIRECT_REMOTE_USER</var>&#039;</dt>
     <dd>
      <span class="simpara">
        验证的用户，如果请求已在内部重定向。
      </span>
     </dd>
    
    
     <dt>&#039;<var class="varname">SCRIPT_FILENAME</var>&#039;</dt>
     <dd>
      <p class="para">
       当前执行脚本的绝对路径。
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
         如果在命令行界面（Command Line Interface, CLI）使用相对路径执行脚本，例如 <var class="filename">file.php</var> 或 <var class="filename">../file.php</var>，那么 <var class="varname">$_SERVER['SCRIPT_FILENAME']</var> 将包含用户指定的相对路径。
        </p>
       </p></blockquote>
      </p>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_ADMIN</var>&#039;</dt>
     <dd>
      <span class="simpara">
       该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上，则该值是那个虚拟主机的值。 
      </span>
     </dd>
    
    
    
     <dt>&#039;<var class="varname">SERVER_PORT</var>&#039;</dt>
     <dd>
      <span class="simpara">
        Web 服务器使用的端口。默认值为 <code class="literal">&#039;80&#039;</code>。如果使用 SSL 安全连接，则这个值为用户设置的 HTTP 端口。
      </span>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <span class="simpara">
        在 Apache 2 里，为了获取真实物理端口，必须设置 <code class="literal">UseCanonicalName = On</code> 以及
        <code class="literal">UseCanonicalPhysicalPort = On</code>，否则可能伪造此值，不一定会返回真实端口值。
        上下文有安全性要求的环境里，不应该依赖此值。
       </span>
      </p></blockquote>
     </dd>
    

    
     <dt>&#039;<var class="varname">SERVER_SIGNATURE</var>&#039;</dt>
     <dd>
      <span class="simpara">
       包含了服务器版本和虚拟主机名的字符串。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">PATH_TRANSLATED</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当前脚本所在文件系统（非文档根目录）的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。
      </span>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <span class="simpara">
        Apache 2 用户可以在 <var class="filename">httpd.conf</var> 中设置 <code class="literal">AcceptPathInfo = On</code> 来定义 <var class="envar">PATH_INFO</var>。
       </span>
      </p></blockquote>
     </dd>
    

    
     <dt>&#039;<var class="varname">SCRIPT_NAME</var>&#039;</dt>
     <dd>
      <span class="simpara">
       包含当前脚本的路径。这在页面需要指向自己时非常有用。<a href="language.constants.magic.php" class="link">__FILE__</a> 常量包含当前脚本(例如包含文件)的完整路径和文件名。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">REQUEST_URI</var>&#039;</dt>
     <dd>
      <span class="simpara">
       URI 用来指定要访问的页面。例如 “<code class="literal">/index.html</code>”。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">PHP_AUTH_DIGEST</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当作为 Apache 模块运行时，进行 HTTP Digest 认证的过程中，此变量被设置成客户端发送的“Authorization” HTTP 头内容（以便作进一步的认证操作）。 
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">PHP_AUTH_USER</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当 PHP 运行在 Apache 或 IIS（PHP 5 是 ISAPI）模块方式下，并且正在使用 HTTP 认证功能，这个变量便是用户输入的用户名。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">PHP_AUTH_PW</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当 PHP 运行在 Apache 或 IIS（PHP 5 是 ISAPI）模块方式下，并且正在使用 HTTP 认证功能，这个变量便是用户输入的密码。 
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">AUTH_TYPE</var>&#039;</dt>
     <dd>
      <span class="simpara">
       当 PHP 运行在 Apache 模块方式下，并且正在使用 HTTP 认证功能，这个变量便是认证的类型。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">PATH_INFO</var>&#039;</dt>
     <dd>
      <span class="simpara">
       如果存在的话，包含由客户端提供的、跟在真实脚本名称之后并且在查询字符串之前的路径信息。例如，如果当前脚本是通过
       URI <var class="filename">http://www.example.com/php/path_info.php/some/stuff?foo=bar</var> 访问，那么
       <var class="varname">$_SERVER['PATH_INFO']</var> 将包含 <code class="literal">/some/stuff</code>。
      </span>
     </dd>
    

    
     <dt>&#039;<var class="varname">ORIG_PATH_INFO</var>&#039;</dt>
     <dd>
      <span class="simpara">
       在被 PHP 处理之前，“<var class="varname">PATH_INFO</var>” 的原始版本。
      </span>
     </dd>
    

   </dl>
  </p>
 </div>


 <div class="refsect1 examples" id="refsect1-reserved.variables.server-examples">
  <h3 class="title">示例</h3>
  <p class="para">
   <div class="example" id="variable.server.basic">
    <p><strong>示例 #1 <var class="varname">$_SERVER</var> 范例</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /></span><span style="color: #007700">echo </span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">'SERVER_NAME'</span><span style="color: #007700">];<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>以上示例的输出类似于：</p></div>
    <div class="example-contents screen">
<div class="examplescode"><pre class="examplescode">www.example.com</pre>
</div>
    </div>
   </div>
  </p>
 </div>

 
 <div class="refsect1 notes" id="refsect1-reserved.variables.server-notes">
  <h3 class="title">注释</h3>
  <blockquote class="note"><p><strong class="note">注意</strong>: <p class="para">“Superglobal”也称为自动化的全局变量。这就表示其在脚本的所有作用域中都是可用的。不需要在函数或方法中用
<strong class="command">global $variable;</strong> 来访问它。</p></p></blockquote>
 </div>


 <div class="refsect1 seealso" id="refsect1-reserved.variables.server-seealso">
  <h3 class="title">参见</h3>
  <p class="para">
   <ul class="simplelist">
    <li><a href="book.filter.php" class="link">过滤器扩展</a></li>
   </ul>
  </p>
 </div>


</div><?php manual_footer($setup); ?>