PHP详解$_SEVER常用变量

时间:2023-03-09 05:55:13
PHP详解$_SEVER常用变量
$_SERVER['HTTP_ACCEPT_LANGUAGE']//浏览器语言
$_SERVER['HTTP_ACCEPT'] //当前请求的Accept头部的内容,例如text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
$_SERVER['HTTP_ACCEPT_CHARSET'] //当前请求头中 Accept-Charset: 项的内容,如果存在的话。例如:“iso-8859-1,*,utf-8”。
$_SERVER['HTTP_ACCEPT_ENCODING'] //当前请求的 Accept-Encoding: 头部的内容。 例如 gzip, deflate, sdch
$_SERVER['HTTP_CONNECTION'] //当前请求的 Connection: 头部的内容。例如:“Keep-Alive”。
$_SERVER['HTTP_HOST'] //当前请求的 Host: 头部的内容。 一般是域名或者IP地址加端口。例如 127.0.0.1:8001
$_SERVER['HTTP_REFERER'] //前一页面的URL,由用户代理决定.并不是所有的用户代理都会设置该项,有的还提供了修改HTTP_REFERER的功能.简言之,该值并不可信
$_SERVER['HTTP_USER_AGENT'] //当前请求的 User_Agent: 头部的内容。
$_SERVER['HTTPS']//如果通过https访问,则被设为一个非空的值(on),否则返回off $_SERVER['REMOTE_ADDR'] //客户端IP地址
$_SERVER['REMOTE_HOST'] //当前用户主机名
$_SERVER['REMOTE_PORT'] //客户端请求端口 $_SERVER['REQUEST_URI'] //URL域名和端口后面的路径地址
$_SERVER['REQUEST_TIME_FLOAT'] #请求开始时的时间戳,微秒级别的精准度。 自 PHP 5.4.0 开始生效。 例如 1469758054.027
$_SERVER['REQUEST_TIME'] #请求开始时的时间戳。从 PHP 5.1.0 起可用。 例如 1469758054
$_SERVER['REQUEST_METHOD']//访问页面时的请求方法 包括 GET POST HEAD PUT $_SERVER['SERVER_NAME'] //当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定。
$_SERVER['SERVER_SOFTWARE'] //服务器标识的字串。例如 Apache/2.4.6 (CentOS) PHP/5.4.16
$_SERVER['SERVER_PROTOCOL'] //请求页面时通信协议的名称和版本。例如 HTTP/1.1
$_SERVER['SERVER_ADMIN'] #该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。
$_SERVER['SERVER_PORT'] #服务器所使用的端口
$_SERVER['SERVER_SIGNATURE'] #包含服务器版本和虚拟主机名的字符串。 $_SERVER['argv'] //传递给该脚本的参数的数组.当脚本以命令行方式运行时.argv变量传递给程序C语言样式的命令行参数.当通过GET方式调用时.
$_SERVER['argc'] //包含命令行模式下传递给该脚本的参数的数目(如果运行在命令行模式下)。
$_SERVER['PHP_SELF']//正在执行脚本的文件名,如果是类似于laravel框架,就是大入口文件index.php
$_SERVER['GATEWAY_INTERFACE']//CGI 规范的版本。 例如 CGI/1.1
$_SERVER['QUERY_STRING'] //查询(query)的字符串。 通过GET方式在URL中的参数
$_SERVER['DOCUMENT_ROOT'] //当前运行脚本所在的文档根目录,绝对路径
$_SERVER['SCRIPT_FILENAME'] #当前执行脚本的绝对路径名。
$_SERVER['PATH_TRANSLATED'] #当前脚本所在文件系统(不是文档根目录)的基本路径。
$_SERVER['SCRIPT_NAME'] #包含当前脚本的路径。这在页面需要指向自己时非常有用。

常见应用

获取客户端IP地址

/** 来自thinkPHP
* 获取客户端IP地址
* @param integer $type 返回类型 0 返回IP地址 1 返回IPV4地址数字
* @param boolean $adv 是否进行高级模式获取(有可能被伪装)
* @return mixed
*/
function get_client_ip($type = 0,$adv=false) {
$type = $type ? 1 : 0;
static $ip = NULL;
if ($ip !== NULL) return $ip[$type];
if($adv){
if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$arr = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
$pos = array_search('unknown',$arr);
if(false !== $pos) unset($arr[$pos]);
$ip = trim($arr[0]);
}elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {
$ip = $_SERVER['HTTP_CLIENT_IP'];
}elseif (isset($_SERVER['REMOTE_ADDR'])) {
$ip = $_SERVER['REMOTE_ADDR'];
}
}elseif (isset($_SERVER['REMOTE_ADDR'])) {
$ip = $_SERVER['REMOTE_ADDR'];
}
// IP地址合法验证
$long = sprintf("%u",ip2long($ip));
$ip = $long ? array($ip, $long) : array('0.0.0.0', 0);
return $ip[$type];
}