目录
- $_SERVER['USER']
- $_SERVER['HOME']
- $_SERVER['HTTP_COOKIE']
- $_SERVER['HTTP_ACCEPT_LANGUAGE']
- $_SERVER['HTTP_ACCEPT_ENCODING']
- $_SERVER['HTTP_ACCEPT']
- $_SERVER['HTTP_USER_AGENT']
- $_SERVER['HTTP_UPGRADE_INSECURE_REQUESTS']
- $_SERVER['HTTP_CACHE_CONTROL']
- $_SERVER['HTTP_PRAGMA']
- $_SERVER['HTTP_CONNECTION']
- $_SERVER['HTTP_HOST']
- $_SERVER['REDIRECT_STATUS']
- $_SERVER['SERVER_NAME']
- $_SERVER['SERVER_PORT']
- $_SERVER['SERVER_ADDR']
- $_SERVER['REMOTE_PORT']
- $_SERVER['REMOTE_ADDR']
- $_SERVER['SERVER_SOFTWARE']
- $_SERVER['GATEWAY_INTERFACE']
- $_SERVER['REQUEST_SCHEME']
- $_SERVER['SERVER_PROTOCOL']
- $_SERVER['DOCUMENT_ROOT']
- $_SERVER['DOCUMENT_URI']
- $_SERVER['REQUEST_URI']
- $_SERVER['SCRIPT_NAME']
- $_SERVER['CONTENT_LENGTH']
- $_SERVER['CONTENT_TYPE']
- $_SERVER['REQUEST_METHOD']
- $_SERVER['QUERY_STRING']
- $_SERVER['SCRIPT_FILENAME']
- $_SERVER['FCGI_ROLE']
- $_SERVER['PHP_SELF']
- $_SERVER['REQUEST_TIME_FLOAT']
- $_SERVER['REQUEST_TIME']
$_SERVER[‘USER’]
echo $_SERVER['USER'];
www-data #为执行当前脚本的用户
三种验证方式
1.grep php-fpm的配置文件
$grep 'www-data' /etc/php/7.2/fpm/pool.d/www.conf
user = www-data
group = www-data
listen.owner = www-data
listen.group = www-data
2.ps | grep 查看当前运行fpm的用户
$ ps aux | grep 'php-fpm' | grep -v 'grep'
www-data 641 0.0 0.1 549964 31000 ? S 5月13 0:01 php-fpm: pool www
root 957 0.0 0.1 468140 26232 ? Ss 5月11 0:15 php-fpm: master process (/etc/php/7.2/fpm/php-fpm.conf)
www-data 1001 0.0 0.1 549988 32072 ? S 5月11 0:04 php-fpm: pool www
www-data 1002 0.0 0.1 550132 31520 ? S 5月11 0:04 php-fpm: pool www
3.当前用户命令行执行查看
$ php -a
Interactive mode enabled
php > echo $_SERVER['USER'];
jinbo
Array
php > echo getenv('USER');
jinbo
$_SERVER[‘HOME’]
echo $_SERVER['HOME']
/var/www #当执行用户的home路径
两种验证方式
1.grep /etc/passwd
$ egrep 'www-data|jinbo' /etc/passwd
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
jinbo:x:1000:1000:jinbo,,,:/home/jinbo:/bin/bash
2.当前用户命令行执行查看
$ php -a
Interactive mode enabled
php > echo $_SERVER['HOME'];
/home/jinbo
php > echo getenv('HOME');
/home/jinbo
$_SERVER[‘HTTP_COOKIE’]
echo $_SERVER['HTTP_COOKIE'];
cookie1=test1; cookie2=test2; cookie3=test3; ...
#打印浏览器上本网站所有的cookie值以“; ” (冒号+空格)分割变成字符串
验证方式
$_SERVER[‘HTTP_ACCEPT_LANGUAGE’]
echo $_SERVER['HTTP_ACCEPT_LANGUAGE'];
en-US,en;q=0.9,zh-CN;q=0.8,zh;q=0.7
浏览器支持的语言/语言喜好程度
语言/q(喜爱度) | 备注 |
---|---|
en-Us | 美式英语 |
en | 英语 |
zh-CN | 简体中文 |
zh | 中文 |
q | 语言会携带一个“q”值,来表示用户对该语言的喜好程度(0~1) |
$_SERVER[‘HTTP_ACCEPT_ENCODING’]
echo $_SERVER['HTTP_ACCEPT_ENCODING'];
gzip, deflate #浏览器支持deflate与gzip两种压缩方式
验证方式
$ grep 'gzip' /etc/nginx/nginx.conf
gzip on;
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
服务器必须开启gzip压缩,才能讲返回内容压缩传输给浏览器
其他文档
https://en.wikipedia.org/wiki/HTTP_compression
https://en.wikipedia.org/wiki/Gzip
https://www.apphp.com/tutorials/index.php?page=gzip-and-deflate-compression-in-web-development
$_SERVER[‘HTTP_ACCEPT’]
echo $_SERVER['HTTP_ACCEPT'];
text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
浏览器支持的响应体格式
类型 | 备注 |
---|---|
text/html | 文本流/html 文件 |
application/xhtml+xml | 支持xhtml+xml同时存在 |
application/xml | 支持xml格式 |
image/webp | 支持webp图片压缩方式 |
image/apng | 支持png的位图动画格式 |
q | 为喜好程度(0-1) |
$_SERVER[‘HTTP_USER_AGENT’]
echo $_SERVER['HTTP_USER_AGENT'];
Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/73.0.3683.86 Chrome/73.0.3683.86 Safari/537.36
解释说明
字段 | 备注 |
---|---|
Mozilla | MozillaProductSlice。声称是基于Mozilla的用户代理,仅适用于Firefox和Netscape等Gecko浏览器。对于所有其他用户代理,它意味着“Mozilla兼容”。在现代浏览器中,这仅用于历史原因。它已经没有实际意义了。在过去,如果user agent不包含“mozilla”等子字符串,有些网站会拒绝向具有用户代理字符串的浏览器提供某些类型的内容(如内联帧),比如说当时的IE,微软通过扮演Mozilla来解决这个问题 |
5.0 | Mozilla 版本 |
X11 | X11是X Window系统的当前版本。X Window系统,通常简称为X,是在类Unix 操作系统上管理GUI(图形用户界面)的主要系统。 |
Linux x86_64 | linux 操作系统 |
AppleWebKit | Web Kit提供了一组核心类,用于在Windows中显示Web内容(注:windows 非 微乳操作系统,而是浏览器的一个窗口) |
537.36 | Web Kit 构建 |
(KHTML, like Gecko) | KHTML由KDE项目开发的开源HTML布局引擎,类似Gecko |
Ubuntu Chromium/73.0.3683.86 Chrome/73.0.3683.86 | 运行在ubuntu系统chromium/chrome |
Safari/537.36 | Based on Safari 537.36 构建 |
$_SERVER[‘HTTP_UPGRADE_INSECURE_REQUESTS’]
echo $_SERVER['HTTP_UPGRADE_INSECURE_REQUESTS'];
1
#1代表浏览器支持安全访问,如果有这个标签为字段 nginx层可以判断浏览器是否支持https
$_SERVER[‘HTTP_CACHE_CONTROL’]
echo $_SERVER['HTTP_CACHE_CONTROL'];
no-cache
#表示禁用缓存提交请求
$_SERVER[‘HTTP_PRAGMA’]
echo $_SERVER['HTTP_PRAGMA'];
no-cache
#表示禁用缓存提交请求
$_SERVER[‘HTTP_CONNECTION’]
echo $_SERVER['HTTP_CONNECTION'];
keep-alive
#表示tcp长链接
参数详解
http_connection | 备注 |
---|---|
keep-alive | tcp长链接 |
close | 短链接 |
different keep-alive with close | keep-alive 建立一次tcp链接,再次打开无需再次建立tcp链接,close是每次都需建立tcp链接,请求结束后关闭tcp链接 |
$_SERVER[‘HTTP_HOST’]
echo $_SERVER['HTTP_HOST'];
example.com
#访问的网站域名
$_SERVER[‘REDIRECT_STATUS’]
echo $_SERVER['REDIRECT_STATUS'];
200
详解及验证
$ egrep 'redirect|REDIRECT' /etc/nginx/fastcgi_params
# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;
# php 作为web服务时处理语言时独有
$_SERVER[‘SERVER_NAME’]
echo $_SERVER['SERVER_NAME'];
example.com
http://nginx.org/en/docs/http/server_names.html
$_SERVER[‘SERVER_PORT’]
echo $_SERVER['SERVER_PORT'];
80 #访问端口号
$_SERVER[‘SERVER_ADDR’]
echo $_SERVER['SERVER_ADDR'];
127.0.0.1 #服务器IP
$_SERVER[‘REMOTE_PORT’]
echo $_SERVER['REMOTE_PORT'];
49050
#浏览器访问的端口
$_SERVER[‘REMOTE_ADDR’]
echo $_SERVER['REMOTE_ADDR'];
127.0.0.1
#浏览器访问IP
#有中间层代理的时候需要真是获取IP需访问 HTTP_CLIENT_IP 或 HTTP_X_FORWARDED_FOR
$_SERVER[‘SERVER_SOFTWARE’]
echo $_SERVER['SERVER_SOFTWARE'];
nginx/1.14.0
#nginx 版本
$_SERVER[‘GATEWAY_INTERFACE’]
echo $_SERVER['GATEWAY_INTERFACE'];
CGI/1.1
#CGI标准
$_SERVER[‘REQUEST_SCHEME’]
echo $_SERVER['REQUEST_SCHEME'];
http #http访问模式
$_SERVER[‘SERVER_PROTOCOL’]
echo $_SERVER['SERVER_PROTOCOL'];
HTTP/1.1 #http1.1协议标准
$_SERVER[‘DOCUMENT_ROOT’]
echo $_SERVER['DOCUMENT_ROOT'];
/var/www
#网站的跟目录
$_SERVER[‘DOCUMENT_URI’]
echo $_SERVER['DOCUMENT_URI'];
/index.php
#实际访问的路径
$_SERVER[‘REQUEST_URI’]
echo $_SERVER['REQUEST_URI'];
/?test=111
#请求路径标识
$_SERVER[‘SCRIPT_NAME’]
echo $_SERVER['SCRIPT_NAME'];
/index.php
#实际访问文件名称
$_SERVER[‘CONTENT_LENGTH’]
echo $_SERVER['CONTENT_LENGTH'];
#1、在Http 1.0及之前版本中,content-length字段可有可无。
#2、在http1.1及之后版本。如果是keep alive,则content-length和chunk必然是二选一。若是非keep alive,则和http1.0一样。content-length可有可无。
$_SERVER[‘CONTENT_TYPE’]
echo $_SERVER['CONTENT_TYPE'];
#不限制访问类型
$_SERVER[‘REQUEST_METHOD’]
echo $_SERVER['REQUEST_METHOD'];
GET
#可以为 GET POST REQUEST(包含$_GET, $_POST, $_COOKIE )
$_SERVER[‘QUERY_STRING’]
echo $_SERVER['QUERY_STRING'];
test=111
#url参数
$_SERVER[‘SCRIPT_FILENAME’]
echo $_SERVER['SCRIPT_FILENAME'];
/var/www/index.php
#服务器访问文件路径
#同 __FILE__
$_SERVER[‘FCGI_ROLE’]
echo $_SERVER['FCGI_ROLE'];
RESPONDER
#FCGI的角色类型为响应
$_SERVER[‘PHP_SELF’]
echo $_SERVER['PHP_SELF'];
/index.php
#访问的文件
$_SERVER[‘REQUEST_TIME_FLOAT’]
echo $_SERVER['REQUEST_TIME_FLOAT'];
1557999340.1493
#访问时间带毫秒数
$_SERVER[‘REQUEST_TIME’]
echo $_SERVER['REQUEST_TIME'];
1557999340
#访问时间不带毫秒
官方文档:https://www.php.net/manual/en/reserved.variables.server.php