// 变量的本质是数据共享
// 函数的本质是代码共享
序号 | 作用域 | 描述 |
---|---|---|
1 | 函数作用域 | 使用function 关键字创建的作用域 |
2 | 全局作用域 | 函数之外的变量生效范围 |
序号 | 变量类型 | 描述 |
---|---|---|
1 | 私有变量 | 函数中定义的变量 |
2 | 全局变量 | 函数之外定义的变量 |
3 | 超全局变量 | 也叫预定义变量,访问不受作用域限制 |
序号 | 变量名 | 描述 |
---|---|---|
1 | $GLOBALS |
引用全局作用域中可用的全部变量 |
2 | $_SERVER |
服务器和执行环境信息 |
3 | $_GET |
HTTP GET 请求:通过 URL 参数传递给当前脚本的变量的数组 |
4 | $_POST |
HTTP POST 请求: 将变量以关联数组形式传入当前脚本 |
5 | $_FILES |
HTTP 文件上传变量,保存着上传文件的全部信息 |
6 | $_COOKIE |
通过 HTTP Cookies 方式传递给当前脚本的变量的数组 |
7 | $_SESSION |
当前脚本可用 SESSION 变量的数组 |
8 | $_REQUEST |
默认情况下包含了 $_GET ,$_POST 和 $_COOKIE 的数组 |
9 | $_ENV |
通过环境方式传递给当前脚本的变量的数组 |
//全局作用于
$siteName = 'php中文网';
// print_r($GLOBALS['siteName']);
function getinfo() : string
{
// global $siteName;
$private = $GLOBALS['siteName'];
echo $_SERVER['SCRIPT_NAME'].'<br>';
return $private;
}
echo getInfo();
static
修饰,并且与函数作用域绑定0
namespace ns1;
function test1():float
{
$sum = 0;
$sum = $sum + 1;
return $sum;
}
echo test1(), '<br>';
echo test1(), '<br>';
echo test1(), '<br>';
echo '<hr>';
namespace ns2;
function test1():float
{
static $sum = 0;
$sum = $sum + 1;
return $sum;
}
echo test1(), '<br>';
echo test1(), '<br>';
echo test1(), '<br>';
// 变量的本质是数据共享
// 函数的本质是代码共享
int => 257
boolean => 258
float => 259
validate_regexp => 272
validate_domain => 277
validate_url => 273
validate_email => 274
validate_ip => 275
validate_mac => 276
string => 513
stripped => 513
encoded => 514
special_chars => 515
full_special_chars => 522
unsafe_raw => 516
email => 517
url => 518
number_int => 519
number_float => 520
magic_quotes => 521
add_slashes => 523
callback => 1024
foreach (filter_list() as $filter) {
echo $filter . ' => ' . filter_id($filter) . '<br>';
}
1、过滤单个变量 fiter_var
$age = 30;
$age = '30';
$age = 68;
var_dump(filter_var($age, FILTER_VALIDATE_INT,['options'=>['min_range'=>18,'max_range'=>60]]));
echo '<hr>';
$email = 'admin@php.cn';
$email = 'admin@';
var_dump(filter_var($email, FILTER_VALIDATE_EMAIL));
var_dump(filter_var($email, 274));
2.过滤多个变量 filter_var_array
/ 2. 过滤单个变量filter_var_array()
var_dump(filter_var_array([100, 'php'], FILTER_VALIDATE_INT));
echo '<hr>';
3.检测是否存在指定的外部变量, filter_has_var()
filter_input 更安全
// 对于URL中的查询字符串: 在URL地址?后面的键值对
// php.cn/index.php?
// id=10
// name=admin
// INPUT_GET: 表示要检测的是$_GET,就是get参数,其实就是get请求
// INPUT_GET, INPUT_POST, INPUT_COOKIE, INPUT_SERVER, INPUT_ENV
var_dump(filter_has_var(INPUT_GET, 'page'));
echo '<hr>';
echo 'get变量p = ' . $_GET['p'];
echo '<hr>';
/ 4. 访问外部变量的过滤器,filter_input
var_dump(filter_input(INPUT_GET, ‘p’,FILTER_VALIDATE_INT, [‘options’=>[‘min_range’=>1]]));
// echo filter_input(INPUT_GET, ‘p’,FILTER_VALIDATE_INT, [‘options’=>[‘min_range’=>1]]) ? ‘页码OK’: ‘页码非法’;
// 5. 同时验证多个外部变量: filter_input_array()
echo ‘<hr>‘;
$args = [
‘username’ => FILTER_SANITIZE_STRING,
‘email’ => FILTER_VALIDATE_EMAIL,
‘age’ => [‘filter’ => FILTER_VALIDATE_INT, ‘flags’=>FILTER_REQUIRE_SCALAR, ‘options’ => [‘min_range’ => 18]],
‘blog’ => FILTER_VALIDATE_URL,
];
// 标量:单值变量, 字符串, 布尔, 数值,
// 复合: 对象, 数组
var_dump(filter_input_array(INPUT_GET, $args));
序号 | 特征 |
---|---|
1 | 常量前面没有美元符号$ |
2 | 常量创建时必须初始化 |
3 | 常量禁止更新和删除 |
4 | 常量不受作用域限制 |
5 | 推荐使用大写字母加下划线命名 |
序号 | 定义方式 | 描述 |
---|---|---|
1 | get_defined_constants() |
查看系统所有常量 |
2 | defined() |
检测常量是否存在 |
3 | define() |
创建常量 |
4 | const 关键字 |
创建常量 |
5 | constant() |
获取常量值 |
get_defined_constants(true)
: 常量分组打印,自定义常量在user
分组defined()
: 返回布尔值预定义常量非常多,有许多与具体扩展相关,如 PDO
, 这里仅列出系统级常用的:
序号 | 预定义常量 | 描述 |
---|---|---|
1 | PHP_VERSION |
PHP 版本 |
2 | PHP_MAXPATHLEN |
PHP 路径最大长度:1024 |
3 | PHP_OS_FAMILY |
操作系统:Windows/Darwin/Linux |
4 | PHP_SAPI |
web 服务器与 php 之间接口: apache2handler |
5 | PHP_EOL |
行尾结束符 |
6 | PHP_INT_MAX |
最大整数: 9223372036854775807 |
7 | PHP_INT_MIN |
最小整数: -9223372036854775808 |
8 | PHP_INT_SIZE |
整数宽度: 8 |
9 | PHP_FLOAT_MAX |
最大浮点数:1.7976931348623E+308 |
10 | PHP_FLOAT_MIN |
整小浮点数: 2.2250738585072E-308 |
11 | DEFAULT_INCLUDE_PATH |
默认 PHP 命令路径 |
12 | PHP_EXTENSION_DIR |
默认 PHP 扩展路径 |
13 | E_ERROR |
运行时错误: 致命中断 |
14 | E_PARSE |
语法解析错误: 致命中断 |
15 | E_NOTICE |
运行时提示: 不中断 |
16 | E_WARNING |
运行时警告: 不中断 |
17 | E_ALL |
所有级别错误(除E_STRICT ) |
18 | E_STRICT |
更加严格的错误处理机制,高于E_ALL |
19 | TRUE |
布尔真 |
20 | FALSE |
布尔假 |
21 | NULL |
空 |
22 | DIRECTORY_SEPARATOR |
目录分隔符 |
更多预定义常量:https://www.php.net/manual/zh/reserved.constants.php
上机演示:
<?php
# 定义常量
// define()函数
define('LECTURE', '朱老师');
// const 关键字
const COURSE = 'PHP';
// 常量不受作用域限制
function test1()
{
echo LECTURE . '教: ' . COURSE . '<br>';
define('SEX', '男');
echo SEX . '<br>';
// const不能用在函数中
// const AGE = 30;
// echo AGE;
}
test1();
echo '<hr>';
// 流程控制中,define能用, const不能用
if (true) {
define('EMAIL', 'admin@php.cn');
// const EMAIL = 'admin@php.cn';
// echo EMAIL;
}
// const用在类中,创建类常量
class Demo
{
const HELLO = 'php.cn';
// define('A', 100);
}
echo Demo::HELLO.'<br>';
// echo Demo::A.'<br>';
// 常量通常只允许用标量进行初始化
// 标量: 单值变量, 字符串, 数值,布尔, null
// php7.0+支持数组初始化常量
const DB_LINKS = [
'host'=>'localhost',
'username'=>'root',
'password'=>'root',
'charset'=>'utf8',
];
echo '<pre>'.print_r(DB_LINKS,true).'</pre>';
// constant()
echo constant('LECTURE'). '<br>';
echo LECTURE. '<br>';
$constantName = 'EMAIL';
echo constant($constantName);
echo '<hr>';
define('USER_NAME', '其实我也是一个常量');
define('', '其实我也是一个常量');
echo '';
echo constant('');
序号 | 魔术常量 | 描述 |
---|---|---|
1 | __LINE__ |
文件中的当前行号 |
2 | __FILE__ |
文件的完整路径和文件名 |
3 | __DIR__ |
文件所在目录 |
4 | __FUNCTION__ |
当前的函数名称 |
5 | __CLASS__ |
当前类名称 |
6 | __TRAIT__ |
当前Trait 名称 |
7 | __METHOD__ |
当前类方法名称 |
8 | __NAMESPACE__ |
当前命名空间名称 |
上机演示:
echo '当前行号: ' . __LINE__ . '<br>';
echo '当前文件: ' . __FILE__ . '<br>';
echo '当前目录: ' . __DIR__ . '\demo6.php<br>';
function hello123()
{
echo __FUNCTION__;
}
hello123();
echo '<hr>';
class D
{
public function index()
{
echo __METHOD__;
}
}
(new D)->index();
知识很多,逻辑上明白,记忆力有点吃不消,玩命记,能学会和能用在项目上估计还是任重道远,好在有一些互联网从业的基础,因此知道我这些代码知识都是补课,朱老师说过出来混迟早要还,感同身受。互联网从业也小十年了,一直以来吃亏在不懂代码上,补上这课是为了飞的更远,加油!