$_SERVER && getenv()函数 详解

$_SERVER['HTTP_ACCEPT_LANGUAGE']//浏览器语言 
$_SERVER['REMOTE_HOST'] //当前用户主机名 
$_SERVER['REQUEST_URI'] //URL
获取IP
$_SERVER["HTTP_X_FORWARDED_FOR"] //透过**代理服务器**取得客户端的真实 IP 地址
$_SERVER['HTTP_CLIENT_IP']// 是代理服务器发送的HTTP头。如果是“超级匿名代理”,则返回none值。同样,REMOTE_ADDR也会被替换为这个代理服务器的IP。
$_SERVER['REMOTE_ADDR'] //当前用户 IP 如果使用了“匿名代理”,REMOTE_ADDR将显示代理服务器的IP。 

$_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 认证功能,这个变量便是认证的类型

获取ip判断


在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代码;

 

你可能感兴趣的:(php)