PHP7新特性

摘要:
PHP标量类型和返回值类型声明默认情况下,所有PHP文件都处于弱类型验证模式python';PHP太空船运算符PHP7新添加的太空船运算符用于比较两个表达式$a和$b。如果$a小于、等于或大于$b,则返回-1、0或1PHP过滤PHP7增加了对unserialize()进行过滤的功能,这可以防止非法数据注入代码,并提供更安全的反序列化数据˂?PHP7通过引入几个CSPRNG函数,提供了一种生成加密强随机数的简单机制。

PHP标量类型与返回值类型声明

默认情况下,所有的PHP文件都处于弱类型校验模式。

PHP 7 增加了标量类型声明的特性,标量类型声明有两种模式: 

  • 强制模式 (默认) 
  • 严格模式

declare(strict_types=1);

代码中通过指定 strict_types的值(1或者0),1表示严格类型校验模式,作用于函数调用和返回语句;0表示弱类型校验模式

可以使用的类型参数有:

  • int

  • float

  • bool

  • string

  • interfaces

  • array

  • callable

<?php 
// 强制模式 
function sum(int ...$ints) 
{ 
   return array_sum($ints); 
} 

print(sum(2, '3', 4.1)); 
?>

//9

<?php 
// 严格模式 
declare(strict_types=1); 

function sum(int ...$ints) 
{ 
   return array_sum($ints); 
} 

print(sum(2, '3', 4.1)); 
?>

//PHP Fatal error:  Uncaught TypeError: Argument 2 passed to sum() must be of the type integer, string given, called in……

PHP 7 增加了对返回类型声明的支持,返回类型声明指明了函数返回值的类型

可以声明的返回类型有:

  • int

  • float

  • bool

  • string

  • interfaces

  • array

  • callable

<?php 
declare(strict_types=1); 

function returnIntValue(int $value): int 
{ 
   return $value; 
} 

print(returnIntValue(5)); 
?>

一个新的返回值类型void被引入。 返回值声明为 void 类型的方法要么干脆省去 return 语句,要么使用一个空的 return 语句。 对于 void 函数来说,NULL 不是一个合法的返回值

返回的类型还有 void,定义返回类型为 void 的函数不能有返回值,即使返回 null 也不行

void 函数可以省去 return 语句,或者使用一个空的 return 语句

PHP NULL合并运算符

PHP 7 新增加的 NULL 合并运算符(??)是用于执行isset()检测的三元运算的快捷方式

NULL 合并运算符会判断变量是否存在且值不为NULL,如果是,它就会返回自身的值,否则返回它的第二个操作数

$site = isset($_GET['site']) ? $_GET['site'] :'python';

==>

$site = isset($_GET['site']) ?? 'python';

PHP太空船运算符(组合比较符)

PHP 7 新增加的太空船运算符(组合比较符)用于比较两个表达式 $a 和 $b,如果 $a 小于、等于或大于 $b时,它分别返回-1、0或1

<?php
print(1<=>1);
print(1<=>2);
print(2<=>1);
?>

//0 -1 1

PHP常量数组

在 PHP 5.6 中仅能通过 const 定义常量数组,PHP 7 可以通过 define() 来定义

<?php
define('sites', [
    'Google',
    'Runoob',
    'Taobao'
]);

?>

PHP匿名类

PHP 7 支持通过 new class 来实例化一个匿名类,这可以用来替代一些"用后即焚"的完整类定义

PHP Closure::call()

PHP 7 的 Closure::call() 有着更好的性能,将一个闭包函数动态绑定到一个新的对象实例并调用执行该函数

<?php
class A {
    private $x = 1;
}

//PHP7之前版本定义闭包函数代码
$getXCB = function() {
    return $this->x;
};

//闭包函数绑定到类A上
$getX = $getXCB->bindTo(new A, 'A');

echo $getX();
print(PHP_EOL);

//PHP 7+ 代码
$getX = function() {
    return $this->x;
};
echo $getX->call(new A);
?>
//闭包函数
<?php
function callback($callback) {
    $callback();
}

$var = '字符串';

callback(function() use (&$var){
    echo "闭包函数传参数测试{$var}";
    $var = 1;
});
print($var);
?>

PHP 过滤

PHP 7 增加了可以为 unserialize() 提供过滤的特性,可以防止非法数据进行代码注入,提供了更安全的反序列化数据

<?php
class MyClass1 {
    public $obj1prop;
}

class MyClass2 {
    public $obj2prop;
}

$obj1 = new MyClass1();
$obj1->obj1prop = 1;
$obj2 = new MyClass2();
$obj2->obj2prop = 2;

$serializedObj1 = serialize($obj1);
$serializedObj2 = serialize($obj2);

//默认行为是接收所有类,第二个参数可以忽略
//如果allowed_classes 设置为false,unserialize会将所有对象转换为__PHP_Incomplete_Class对象
$data = unserialize($serializedObj1, ["allowed_classes"=>true]);

//转换所有对象到__PHP_Incomplete_Class对象
$data2 = unserialize($serializedObj2, ["allowed_classes"=>["MyClass1", "MyClass2"]]);
print($data->obj1prop);
echo "<br>";
print($data2->obj2prop);


?>

PHP IntlChar()

PHP CSPRNG

CSPRNG(Cryptographically Secure Pseudo-Random Number Generator,伪随机数产生器)。

PHP 7 通过引入几个 CSPRNG 函数提供一种简单的机制来生成密码学上强壮的随机数。

  • random_bytes() - 加密生存被保护的伪随机字符串。

  • random_int() - 加密生存被保护的伪随机整数。

<?php
//string random_bytes(int $length)
//@param  length-随机字符串返回的字节数
//@return  返回一个字符串,接受一个int型入参代表返回结果的字节数

$bytes = random_bytes(5);
//print($bytes);
print(bin2hex($bytes));

//int random_int (int $min, int $max)
//@param min 返回的最小值,必须是大于或等于PHP_INT_MIN
//@param max 返回的最大值,必须是小于或等于PHP_INT_MAX
//@return 返回一个指定范围内的int型数字

print(random_int(100, 999));
print(random_int(-1000, 0));
?>

PHP 7 异常

PHP 7 use 语句

PHP 7 可以使用一个 use 从同一个 namespace 中导入类、函数和常量:

PHP 7 错误处理

PHP 7 改变了大多数错误的报告方式。不同于 PHP 5 的传统错误报告机制,现在大多数错误被作为 Error 异常抛出。

这种 Error 异常可以像普通异常一样被 try / catch 块所捕获。如果没有匹配的 try / catch 块, 则调用异常处理函数(由 set_exception_handler() 注册)进行处理。 如果尚未注册异常处理函数,则按照传统方式处理:被报告为一个致命错误(Fatal Error)。

Error 类并不是从 Exception 类 扩展出来的,所以用 catch (Exception $e) { ... } 这样的代码是捕获不 到 Error 的。你可以用 catch (Error $e) { ... } 这样的代码,或者通过注册异常处理函数( set_exception_handler())来捕获 Error。

<?php
class MathOperations
{
    protected $n = 10;

    //求余数运算,除数为0,抛出异常
    public function doOperation(): string
    {
        try
        {
            $value = $this->n % 0;
            return $value;
        } catch (DivisionByZeroError $e)
        {
            return $e->getMessage();
        }
    }
}

$mathOperationsObj = new MathOperations();
print($mathOperationsObj->doOperation());
?>

PHP 7 intdiv() 函数

PHP 7 新增加了 intdiv() 函数,接收两个参数,返回值为第一个参数除于第二个参数的值并取整

PHP 7 Session选项

PHP 7 废弃特性

PHP 7 移除的扩展

PHP 7 移出的SAPI

免责声明:文章转载自《PHP7新特性》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇ZYNQ:使用SDK打包BOOT.BIN、烧录BOOT.BIN到QSPI-FLASH轻松实现突破网管限制(SoftEther实际应用)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

RedisDump安装以及常见错误

安装redisdump大部分问题都出在版本的问题,redis-dump是将redis和json互转的工具;redis-dump是基于ruby开发,需要ruby环境,而且新版本的redis-dump要求2.3.0及以上的ruby版本,centos中yum只能安装2.0版本的ruby。需要先安装ruby的管理工具rvm安装高版本的ruby。 rvm安装以及常见...

Bypass_disable_func

1、系统命令执行函数的黑名单绕过 system() shell_exec() === ``反引号 exec() passthru() popen() proc_open() pcntl_exec() dl() // 加载自定义 php 扩展,5.3以后被废弃 2、通过LD_PRELOAD偷梁换柱 先来了解下 LD_PRELOAD: LD_PRELOAD...

如何基于 PHP-X 快速开发一个 PHP 扩展

0x01 起步 PHP-X本身基于C++11开发,使用cmake进行编译配置。首先,你需要确定所有依赖项已安装好。包括: gcc-4.8 或更高版本 PHP7.0 或更高版本,需要php7-dev 开发包 cmake-2.8 或更高版本 然后安装PHP-X。 git clone https://github.com/swoole/PHP-X.git c...

php中mysql数据库操作类 -李盛鹏 -博客园

本白演示的代码属于较为简单的数据库封装类,较适合初学。因为水平有限,见谅。 接着稍微说说整体的思路。整个类的封装,包含一个连接数据库的私有属性$conn和若干操作函数。$conn在对象实例化的时候,由构造函数处理传入的参数后返回一个资源型的连接句柄。而后即可通过调用该实例化的对象的相应方法对数据库进行增删查改的操作。 talk less and show...

Ubuntu 18.04升级matplotlib 3.5

背景 需要使用到matplotlib 3.5的新特性决定升级搜索pip源发现python 3.6最高支持matplotlib 3.2而matplotlib 3.5仅适配python 3.7+ 安装 一定不要尝试卸载18.04自带python 3.6否则系统会崩溃 sudo apt install python3.8 依赖 安装3.8包管理工具 sudo...

自学PHP 环境搭建

自学PHP之环境搭建 一、.首先 安装 phpStudy2013.exe 程序集成包 安装完可能端口被占用 需要手动设置 然后打开http://localhost:8080/phpMyAdmin/ 默认用户名root 密码root 二、 搭建thinkphp框架 先去http://www.thinkphp.cn下载核心包或者完整包 1. 在根...