您好,欢迎访问一九零五行业门户网

一篇文章帮你了解 PHP 7.3 更新

php 目前依旧是其它脚本语言强劲的竞争对手,这主要归功于其核心维护团队的快速更新。
自从 php 7.0 发布以来,社区见证了许多新特性的诞生,极大地改进了开发者在项目中应用 php 的方式。提高 php 应用的性能和安全性,是这些改进的主要目的。
php 最近实现了又一个里程碑 —— 发布 php 7.3。新版本带来了一些急需的更新。
在本文中,我将论述新推出的 php 7.3 特性 和更新。好消息是,你可以在你的测试服务器上自行安装新版本、查看新功能。但老生常谈,切勿在生产服务器上使用 rc 版本更新,可能会破坏你已经上线的应用。
以下是7.3版中引入的一些更新,与以前的版本相比,它们大大提高了 php 7.3 的性能 。
灵活的 heredoc 和 nowdoc 语法函数调用时允许尾随逗号json_throw_on_errorpcre2 迁移list() 分配参考is_countable 函数array_key_first(), array_key_last()argon2 密码哈希增强功能弃用和删除 image2wbmp()弃用和删除不区分大小写的常量相同站点 cookiefpm 更新改进 windows 下的文件删除让我们逐一讨论上述的每一个更新。
灵活的 heredoc 和 nowdoc 语法heredoc 和 nowdoc 语法能够在使用多行长字符串时起到很大帮助。它要求结束标识符应当为出现在新行的首个字符串。
// 除了这样:$query = <<<sqlselect *from `table`where `column` = true;sql;// 这样也可以:$query = <<<sql select * from `table` where `column` = true; sql;
总的来说,此更新提出了两项改进,如下:
闭合标识符前支持缩进闭合标识符后不再强制换行在上面的例子里,可以很容易地看出这些改动。
函数调用中允许尾部逗号在参数、元素、变量列表结尾,追加尾部逗号。有时我们在数组内以及函数调用(尤其是可变参函数)时需要传递大量元素,若是漏掉一个逗号,便会报错。鉴于如上情况,尾部逗号便显得十分有用。这个特性已经允许在数组内使用,并且从 php 7.2 开始,分组命名空间(grouped namespaces)语法也开始支持尾部逗号。
use foo\bar\{ foo, bar,};$foo = [ 'foo', 'bar',];
当新值需要被追加在此处时,尾部逗号便显得十分实用。在可变参函数例如 unset() 内,更是如此。
unset( $foo, $bar, $baz,);
同时,当你使用 compact() 函数给模版引擎传递一批变量时,也是个能用到的例子。
echo $twig->render(   'index.html',   compact(       'title',       'body',       'comments',   ));
在某些需要构造连续或分组数据情况下,经常要使用 array_merge() 函数合并数组。也可以利用尾部逗号:
$newarray = array_merge(   $arrayone,   $arraytwo,   ['foo', 'bar'],);
同样,你也可以在调用任意方法、函数以及闭包时使用此特性。
class foo{ public function __construct(...$args) {   // } public function bar(...$args) {   // } public function __invoke(...$args) {   // }}$foo = new foo( 'constructor', 'bar',);$foo->bar( 'method', 'bar',);$foo( 'invoke', 'bar',);
json_throw_on_error解析 json 响应数据,有 json_encode() 以及 json_decode() 两个函数可供使用。不幸的是,它们都没有恰当的错误抛出表现。json_encode 失败时仅会返回 false;json_decode 失败时则会返回 null,而 null 可作为合法的 json 数值。唯一获取错误的方法是,调用 json_last_error() 或 json_last_error_msg(),它们将分别返回机器可读和人类可读的全局错误状态。
该 rfc 提出的解决方案是,为 json 函数新增 json_throw_on_error 常量用于忽略全局错误状态。当错误发生时,json 函数将会抛出 jsonexception 异常,异常消息(message)为 json_last_error() 的返回值,异常代码(code)为 json_last_error_msg() 的返回值。如下是调用例子:
json_encode($data, json_throw_on_error);json_decode(invalid json, null, 512, json_throw_on_error);// 抛出 jsonexception 异常
升级 pcre2php 使用 pcre 作为正则表达式引擎。但从 php 7.3 开始,pcre2 将作为新的正则引擎大显身手。所以,你需要将现有的正则表达式迁移到符合 pcre2 的规则。这些规则比以前更具侵入性。请看以下实例:
preg_match('/[\w-.]+/', '');
这个表达式在新版 php 内将会匹配失败且不会触发警告。因为 pcre2 现严格要求,若需匹配连字符(-)而非用于表示范围,则必须移动到末尾或将其转义。
更新到 pcre2 10.x 后,支持了以下以及更多特性:
相对后向引用 \g{+2}(等效于已存在的 \g{-2})pcre2 版本检查 (?(version>=x)...)(*notempty) 和 (*notempty_atstart) 告知引擎勿返回空匹配(*no_jit) 禁用 jit 优化(*limit_heap=d) 限制堆大小为 d kb(*limit_depth=d) 设置回溯深度限制为 d(*limit_match=d) 设置匹配数量限制为 d译者注:国内正则术语参差不一,「后向引用」—— back references,又称「反向引用」、「回溯引用」等,此处参考 php 官方手册的中文译本。
list() 赋值引用php 中的 list() 现在可以赋值给引用,在当前版本中 list() 中赋值不能使用引用,在 php 7.3 中将允许使用引用,新改进的语法如下:
$array = [1, 2];list($a, &$b) = $array;
相当于
$array = [1, 2];$a = $array[0];$b =& $array[1];
在 php 7.3 的变更中,我们还可以与 foreach() 方法一起嵌套使用
$array = [[1, 2], [3, 4]];foreach ($array as list(&$a, $b)) {   $a = 7;}var_dump($array);
is_countable 函数在 php 7.2 中,用 count() 获取对象和数组的数量。如果对象不可数,php 会抛出警告⚠️ 。所以需要检查对象或者数组是否可数。 php 7.3 提供新的函数 is_countable() 来解决这个问题。
该 rfc 提供新的函数 is_countable(),对数组类型或者实现了 countable 接口的实例的变量返回 true 。
之前:
if (is_array($foo) || $foo instanceof countable) {   // $foo 是可数的}
之后:
if (is_countable($foo)) {   // $foo 是可数的}
array_key_first(), array_key_last()当前版本的 php 允许使用 reset() ,end() 和 key() 等方法,通过改变数组的内部指针来获取数组首尾的键和值。现在,为了避免这种内部干扰,php 7.3 推出了新的函数来解决这个问题:
$key = array_key_first($array); 获取数组第一个元素的键名$key = array_key_last($array); 获取数组最后一个元素的键名让我们看一个例子:
// 关联数组的用法$array = ['a' => 1, 'b' => 2, 'c' => 3];$firstkey = array_key_first($array);$lastkey = array_key_last($array);assert($firstkey === 'a');assert($lastkey === 'c');// 索引数组的用法$array = [1 => 'a', 2 => 'b', 3 => 'c'];$firstkey = array_key_first($array);$lastkey = array_key_last($array);assert($firstkey === 1);assert($lastkey === 3);
译者注:array_value_first() 和 array_value_last() 并没有通过 rfc 表决;因此 php 7.3 内仅提供了 array_key_first() 以及 array_key_last() 函数。
参考链接:https://wiki.php.net/rfc/array_key_first_l...
argon2 和 hash 密码加密性能增强在php的早期版本中,我们增加了argon2和哈希密码加密算法,这是一种使用哈希加密算法来保护密码的现代算法。它有三种不同的类型,argon2i,argon2d和argon 2id。 我们针对argon2i密码散列和基于密码的密钥生成进行了优化。 argon2d性能更快,并使用依赖于内存的数据访问。 argon2i使用与内存无关的数据访问。 argon2id是argon2i和argon2d的混合体,使用依赖于数据和与数据独立的存储器访问的组合。
password_hash():
argon2id现在是在paswword_ *函数中使用的推荐的argon2变量。
具有自定义成员方法的名称的argon2id与password_argon2i的使用方法相同password_hash('password',password_argon2id,['memory_cost'=> 1 << 17,'time_cost'=> 4,'threads'=> 2]);
password_verify();
除了argon2i之外,password_verify()函数也适用于argon2id。
password_needs_rehash();
此函数也将接受argon2id哈希值,如果任何变量成员发生变化,则返回true。
$hash = password_hash('password', password_argon2id);password_needs_rehash($hash, password_argon2id); // 返回假password_needs_rehash($hash, password_argon2id, ['memory_cost' => 1<<17]); // 返回真
废弃并移除 image2wbmp()该函数能够将图像输出为 wbmp 格式。另一个名为 imagewbmp() 的函数也同样具备单色转换的作用。因此,出于重复原因,image2wbmp() 现已被废弃,你可使用 imagewbmp() 代替它。此函数被弃用后,再次调用它将会触发已弃用警告。待后续此函数被移除后,再次调用它将会触发致命错误。
废弃并移除大小写不敏感的常量使用先前版本的 php,你可以同时使用大小写敏感和大小写不敏感的常量。但大小写不敏感的常量会在使用中造成一点麻烦。所以,为了解决这个问题,php 7.3 废弃了大小写不敏感的常量。
原先的情况是:
类常量始终为「大小写敏感」。使用 const 关键字定义的全局常量始终为「大小写敏感」。注意此处仅仅是常量自身的名称,不包含命名空间名的部分,php 的命名空间始终为「大小写不敏感」。使用 define() 函数定义的常量默认为「大小写敏感」。使用 define() 函数并将第三个参数设为 true 定义的常量为「大小写不敏感」。如今 php 7.3 提议废弃并移除以下用法:
in php 7.3: 废弃使用 true 作为 define() 的第三个参数。in php 7.3: 废弃使用与定义时的大小写不一致的名称,访问大小写不敏感的常量。true、false 以及 null 除外。同站点 cookiephp 7.3 在建议在使用 cookies 时,增加同站点标志。这个 rfc 会影响4个系统函数。
setcookiesetrawcookiesession_set_cookie_paramssession_get_cookie_params这个影响会在两种情况下起作用。其中一种方式会添加函数的新参数
,另一种方式允许以数组形式的选项代替其他单独选项。
bool setcookie(   string $name   [, string $value =    [, int $expire = 0   [, string $path =    [, string $domain =    [, bool $secure = false   [, bool $httponly = false ]]]]]])bool setcookie (   string $name   [, string $value =    [, int $expire = 0   [, array $options ]]])// 两种方式均可.
fpm 更新fastcgi 进程管理器也进行了更新,现在提供了新的方式来记录 fpm 日志。
log_limit: 设置允许的日志长度,可以超过 1024 字符。
log_buffering: 允许不需要额外缓冲去操作日志。
decorate _workers_output: 当启用了 catch_workers_output 时,系统会去禁用渲染输出。
改进 windows 下的文件删除如官方文档所述:
默认情况下,文件描述符以共享读、写、删除的方式去操作。 这很有效的去映射 posix 并允许去删除正在使用中的文件。但这并不是100%都是一样的,不同的平台可能仍存在一些差异。删除操作之后,文件目录仍存在直到所有的文件操作被关闭。
结束语之前我们已经讲解了最新版本的 php7.3 的特点,包含了许多新增跟弃用的功能。这些功能都可以在 php.net 网站上找到,并且已经合并到主分支上了。你现在就可以使用这些新功能部署在自己的服务器上,你也可以打开官方rfc页面查阅每一个详细版本。如果你对着新版 php7.3 有任何问题,你可以在评论下写下自己的想法。
相关php视频教程推荐:《php视频教程》
以上就是一篇文章帮你了解 php 7.3 更新的详细内容。
其它类似信息

推荐信息