php getenv()函数与$_SERVER区别

项目中需要获取客户端的ip,涉及到getenv()和$_SERVER 。所以将他们整理一下

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 认证功能,这个变量便是用户输入的密码。


$_SERVER没有以下3个参数

“HTTP_X_FORWARDED_FOR”
透过代理服务器取得客户端的真实 IP 地址

HTTP_VIA
代理服务器IP

HTTP_CLIENT_IP
取得用户的IP代码

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

PHP中获取访客(客户端)的ip地址函数getenv(“REMOTE_ADDR”) 与$_SERVER[‘REMOTE_ADDR’]的区别
getenv(“REMOTE_ADDR”)函数在 apache下能正常获取ip地址,而在iis中,不起作用
$_SERVER[‘REMOTE_ADDR’]函数,既可在apache中成功获取 访客的ip地址,在iis下也同样有效

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mr.杰瑞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值