php $_SERVER 学习详解

本文深入探讨PHP中的$_SERVER超级全局变量,包括其各种用途和验证方式,如用户身份验证、浏览器偏好设置、HTTP请求头信息解析等,是理解Web服务器与PHP交互关键的指南。

$_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

解释说明

字段备注
MozillaMozillaProductSlice。声称是基于Mozilla的用户代理,仅适用于Firefox和Netscape等Gecko浏览器。对于所有其他用户代理,它意味着“Mozilla兼容”。在现代浏览器中,这仅用于历史原因。它已经没有实际意义了。在过去,如果user agent不包含“mozilla”等子字符串,有些网站会拒绝向具有用户代理字符串的浏览器提供某些类型的内容(如内联帧),比如说当时的IE,微软通过扮演Mozilla来解决这个问题
5.0Mozilla 版本
X11X11是X Window系统的当前版本。X Window系统,通常简称为X,是在类Unix 操作系统上管理GUI(图形用户界面)的主要系统。
Linux x86_64linux 操作系统
AppleWebKitWeb Kit提供了一组核心类,用于在Windows中显示Web内容(注:windows 非 微乳操作系统,而是浏览器的一个窗口)
537.36Web Kit 构建
(KHTML, like Gecko)KHTML由KDE项目开发的开源HTML布局引擎,类似Gecko
Ubuntu Chromium/73.0.3683.86 Chrome/73.0.3683.86运行在ubuntu系统chromium/chrome
Safari/537.36Based on Safari 537.36 构建

详细信息参考
chromium与chrome区别
X11

$_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-alivetcp长链接
close短链接
different keep-alive with closekeep-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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值