extract — 从数组中将变量导入到当前的符号表
符号表:在计算机科学中,符号表是一种用于语言翻译器(例如编译器和解释器)中的数据结构。在符号表中,程序源代码中的每个标识符都和它的声明或使用信息绑定在一起,比如其数据类型、作用域以及内存地址。
个人理解:符号表是key-value结构,就跟数据库一样。每新建一个变量,就在符号表添加一条记录。
EX:当$a=1时,在符号表添加一条数据,key为a,value为指向内存的地址,假设是0x111222。
说明:
extract ( array &$array [, int $flags = EXTR_OVERWRITE [, string $prefix = NULL ]] ) : int
extract(array,extract_rules,prefix)
本函数用来将变量从数组中导入到当前的符号表中。
检查每个键名看是否可以作为一个合法的变量名,同时也检查和符号表中已有的变量名的冲突。
参数:
$array
一个关联数组。此函数会将键名当作变量名,值作为变量的值。 对每个键/值对都会在当前的符号表中建立变量,并受到 flags
和 prefix
参数的影响。
$flags
对待非法/数字和冲突的键名的方法将根据取出标记 flags
参数决定。可以是以下值之一:
EXTR_OVERWRITE
如果有冲突,覆盖已有的变量。
EXTR_SKIP
如果有冲突,不覆盖已有的变量。
EXTR_IF_EXISTS
仅在当前符号表中已有同名变量时,覆盖它们的值。其它的都不处理。 举个例子,以下情况非常有用:定义一些有效变量,然后从 $_REQUEST 中仅导入这些已定义的变量。
略…
如果没有指定 flags,则被假定为 EXTR_OVERWRITE。!!!
$prefix
略…
返回值:
返回成功导入到符号表中的变量数目。
EX:
<?php
/* 假定 $var_array 是 wddx_deserialize 返回的数组*/
$size = "large";
$var_array = array("color" => "blue",
"size" => "medium",
"shape" => "sphere");
extract($var_array, EXTR_PREFIX_SAME, "wddx");
echo "$color, $size, $shape, $wddx_size\n";
?>
输出:
blue, large, sphere, medium
<?php
$a="hello";
$b= array('a' =>"world" ,"b"=>"gogogo");
extract($b);
echo $a;//在符号表中被$b的a=word覆盖了
?>
输出:
world
file_get_contents — 将整个文件读入一个字符串
说明:
file_get_contents ( string $filename [, bool $use_include_path = false [, resource $context [, int $offset = -1 [, int $maxlen ]]]] ) : string
file_get_contents(path,include_path,context,start,max_length)
和 file() 一样,只除了 file_get_contents() 把文件读入一个字符串。将在参数 offset
所指定的位置开始读取长度为 maxlen
的内容。如果失败,file_get_contents() 将返回 FALSE
。
Note:
如果要打开有特殊字符的 URL (比如说有空格),就需要使用 urlencode() 进行 URL 编码。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GIgQCwDu-1605171272127)(C:\Users\lker\AppData\Roaming\Typora\typora-user-images\image-20201112144010728.png)]
trim — 去除字符串首尾处的空白字符(或者其他字符)
说明:
trim ( string `$str` [, string `$character_mask` = " \t\n\r\0\x0B" ] ) : string
trim(string,charlist)
ini_set — 为一个配置选项设置值
说明:
ini_set ( string $varname , string $newvalue ) : string
设置指定配置选项的值。这个选项会在脚本运行时保持新的值,并在脚本结束时恢复。
参数:
$varname
不是所有有效的选项都能够用 ini_set() 来改变的。 这里有个有效选项的清单附录。
$newvalue
选项新的值。
返回值
成功时返回旧的值,失败时返回 FALSE
。
eror_reporting — 设置应该报告何种 PHP 错误
error_reporting ([ int $level ] ) : int
error_reporting() 函数能够在运行时设置 error_reporting 指令。 PHP 有诸多错误级别,使用该函数可以设置在脚本运行时的级别。 如果没有设置可选参数 level
, error_reporting() 仅会返回当前的错误报告级别。
参数:
$level
新的 error_reporting 级别。 可以是一个位掩码也可以是一个已命名的常量。 强烈建议使用已命名的常量,以确保兼容将来的版本。 由于错误级别的添加、整数取值范围的增加, 较久的基于整数的错误级别不会总是和预期的表现一致。
可用的错误级别常量及其实际含义描述在了 predefined constants 中。
返回值
返回旧的 error_reporting 级别,或者在 level
参数未给出时返回当前的级别。
isset — 检测变量是否已设置并且非NULL
说明:
isset ( mixed $var [, mixed $... ] ) : bool
检测变量是否设置,并且不是 NULL
。
如果已经使用 unset() 释放了一个变量之后,它将不再是 isset()。若使用 isset() 测试一个被设置成 NULL
的变量,将返回 FALSE
。同时要注意的是 null 字符("\0"
)并不等同于 PHP 的 NULL
常量。
如果一次传入多个参数,那么 isset() 只有在全部参数都以被设置时返回 TRUE
计算过程从左至右,中途遇到没有设置的变量时就会立即停止。
参数:
$var
要检查的变量。
…
其他变量。
返回值:
如果 var
存在并且值不是 NULL
则返回 TRUE
,否则返回 FALSE
。
header — 发送原生 HTTP 头
说明:
header ( string $string [, bool $replace = true [, int $http_response_code ]] ) : void
header() 用于发送原生的 HTTP 头。关于 HTTP 头的更多信息请参考 » HTTP/1.1 specification。
请注意 header() 必须在任何实际输出之前调用,不管是普通的 HTML 标签,还是文件或 PHP 输出的空行,空格。
参数:
$string
头字符串
$replace
可选参数 replace
表明是否用后面的头替换前面相同类型的头。 默认情况下会替换。如果传入 FALSE
,就可以强制使相同的头信息并存。
$http_response_code
强制指定HTTP响应的值。注意,这个参数只有在报文字符串(string
)不为空的情况下才有效。
返回值:
没有返回值。
die — 等同于 exit()
说明:
语法结构等同于 exit()。
exit — 输出一个消息并且退出当前脚本
说明:
exit ([ string $status ] ) : void
exit ( int $status ) : void
中止脚本的执行。 尽管调用了 exit(), Shutdown函数 以及 object destructors 总是会被执行。
exit
是个语法结构,如果没有 status
参数要传入,可以省略圆括号。
参数:
status
如果 status
是一个字符串,在退出之前该函数会打印 status
。
如果 status
是一个 int,该值会作为退出状态码,并且不会被打印输出。 退出状态码应该在范围0至254,不应使用被PHP保留的退出状态码255。 状态码0用于成功中止程序。
返回值:
没有返回值。
is_string — 检测变量是否是字符串
说明:
is_string ( mixed $var ) : bool
如果 var
是 string 则返回 TRUE
,否则返回 FALSE
。
参见 is_bool()、is_int()、is_integer()、is_float()、is_real()、is_object() 和 is_array()。
addslashes — 使用反斜线引用字符串
说明:
addslashes ( string $str ) : string
返回字符串,该字符串为了数据库查询语句等的需要在某些字符前加上了反斜线。这些字符是单引号('
)、双引号("
)、反斜线(\
)与 NUL(NULL
字符)。
一个使用 addslashes() 的例子是当你要往数据库中输入数据时。 例如,将名字 O'reilly
插入到数据库中,这就需要对其进行转义。 强烈建议使用 DBMS 指定的转义函数 (比如 MySQL 是 mysqli_real_escape_string(),PostgreSQL 是 pg_escape_string()),但是如果你使用的 DBMS 没有一个转义函数,并且使用 \
来转义特殊字符,你可以使用这个函数。 仅仅是为了获取插入数据库的数据,额外的 \
并不会插入。 当 PHP 指令 magic_quotes_sybase 被设置成 on
时,意味着插入 '
时将使用 '
进行转义。
PHP 5.4 之前 PHP 指令 magic_quotes_gpc 默认是 on
, 实际上所有的 GET、POST 和 COOKIE 数据都用被 addslashes() 了。 不要对已经被 magic_quotes_gpc 转义过的字符串使用 addslashes(),因为这样会导致双层转义。 遇到这种情况时可以使用函数 get_magic_quotes_gpc() 进行检测。
参数:
$str
要转义的字符。
返回值:
返回转义后的字符。
strval — 获取变量的字符串值
说明:
strval ( mixed $var ) : string
返回 var
的 string 值。 参见 string 文档获取更多关于字符串转换的信息。
var
可以是任何标量类型。不能将 strval() 用于数组或对象。
参见 floatval()、intval()、settype() 和类型戏法。
strlen — 获取字符串长度
说明:
strlen ( string `$string` ) : int
返回给定的字符串 string
的长度。
参数:
$string
需要计算长度的字符串。
返回值:
成功则返回字符串 string
的长度(包括空格);如果 string
为空,则返回 0。
intval — 获取变量的整数值
说明:
intval ( mixed $var [, int $base = 10 ] ) : int
通过使用指定的进制 base
转换(默认是十进制),返回变量 var
的 integer 数值。 intval() 不能用于 object,否则会产生 E_NOTICE
错误并返回 1。
参数:
$var
要转换成 integer 的数量值。
$base
转化所使用的进制。
Note:
如果
base
是 0,通过检测var
的格式来决定使用的进制:
- 如果字符串包括了 “0x” (或 “0X”) 的前缀,使用 16 进制 (hex);否则,
- 如果字符串以 “0” 开始,使用 8 进制(octal);否则,
- 将使用 10 进制 (decimal)。
返回值:
成功时返回 var
的 integer 值,失败时返回 0。 空的 array 返回 0,非空的 array 返回 1。
最大的值取决于操作系统。 32 位系统最大带符号的 integer 范围是 -2147483648 到 2147483647。举例,在这样的系统上, intval('1000000000000')
会返回 2147483647。64 位系统上,最大带符号的 integer 值是 9223372036854775807。
字符串有可能返回 0,虽然取决于字符串最左侧的字符。 使用 整型转换 的共同规则。
strrev — 反转字符串
说明:
strrev ( string $string ) : string
返回 string
反转后的字符串。
参数:
$string
待反转的原始字符串。
返回值:
返回反转后的字符串。