$_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”
运行结果:
filter_has_var() 检查是否存在指定输入类型的变量。filter_id() 返回指定过滤器的 ID 号。filter_input() 从脚本外部获取输入,并进行过滤。filter_input_array() 从脚本外部获取多项输入,并进行过滤。filter_list() 返回包含所有得到支持的过滤器的一个数组。filter_var_array() 获取多项变量,并进行过滤。filter_var() 获取一个变量,并进行过滤。
FILTER_CALLBACK:调用用户自定义的函数来过滤数据FILTER_VALIDATE_INT:在指定的范围以整数验证值。FILTER_VALIDATE_BOOLEAN:如果是 “1”, “true”, “on” 以及 “yes”,则返回 true,如果是 “0”, “false”, “off”, “no” 以及 “”,则返回 false。否则返回 NULL。FILTER_VALIDATE_FLOAT:以浮点数验证值。FILTER_VALIDATE_URL:把值作为 URL 来验证。FILTER_VALIDATE_EMAIL:把值作为 e-mail 来验证。FILTER_VALIDATE_IP:把值作为 IP 地址来验证。
// 过滤器// $email = 'admin@php.cn';$email = 'admin@sdfg';//通过过滤器判断EMAIL变量的格式是否正确echo filter_var($email, FILTER_VALIDATE_EMAIL) ? '邮箱格式正确' : '邮箱格式错误';

// 验证请求来源的合法性$refererDir = dirname(filter_input(INPUT_SERVER, 'HTTP_REFERER'));// 允许访问当前页面的url数组: 白名单$urls = [$refererDir. '/login.php',$refererDir. '/admin.php',];// 当前的请求源地址$url = filter_input(INPUT_SERVER, 'HTTP_REFERER');// 判断请求来源是否合法?if (!in_array($url, $urls)) {exit('非法来源');} else {die('合法来源');}

// 自定义过滤器function filter_replace($str){return str_replace('php语言', '编程开发', $str);}$str = 'php中文网是一个专业学习的php语言的网站';echo $str . '<br>';echo filter_var($str, FILTER_CALLBACK, ['options'=>'filter_replace']);

1. 变量序列化
$var = 'php中文网是一个专业学习的php语言的网站';// 变量序列化echo serialize($var);

serialize(): 产生一个可存储的值的表示。返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方。
2. 数组序列化
//创建一个数组$arr = ['admin', '123456', 32,'男', '安徽'];echo serialize($arr);

3. 反序列化
$arr =unserialize('a:5:{i:0;s:5:"admin";i:1;s:6:"123456";i:2;i:32;i:3;s:3:"男";i:4;s:6:"安徽";}');print_r($arr);


Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号