작성 시간: 2022년 12월 8일 오후 10:50
마지막 편집 시간: 2022년 12월 8일 오후 11:58
에서 다시 게시됨PHP 8.2 하이라이트: 새로운 기능 및 변경된 내용
? PHP 8.2는 유형 시스템 개선, 읽기 전용 readonly
클래스, 민감한 매개변수 숨기기 지원, 새로운 무작위 random
확장 등을 포함하여 단순화되고 현대화된 PHP 기능을 제공합니다. readonly
类、敏感参数隐藏支持、新的随机 random
扩展,以及包括简化和现代化 PHP 在内的多项功能。
PHP 8.2 是 PHP 迈入现代化的重要里程碑。除了令人兴奋的新功能和改进之外,PHP 8.2 通过弃用动态属性支持、对 INI 配置值发出警告和修复一系列数组排序和字符串转换的遗留行为。【推荐:PHP视频教程】
PHP 8.2 解决了数个原有类型系统的短处和限制,让 PHP 项目得以拥有更好的类型安全性。这包括添加对 true
类型的支持,并允许将 null
和 false
用作独立类型,同时增加了对 DNF 类型的支持。
Disjoint Normal Form (DNF) 类型支持 - 在 PHP 8.2 中,开发者可以组合使用联合
union
类型(PHP 8.0)和交集intersection
类型(PHP 8.1),继而允许声明更加精确的参数、返回和属性类型。
function process((HTMLRequest & RequestInterface) | APIRequest $request) { // ...}
(HTMLRequest & RequestInterface) | APIRequest
类型声明表示 $request
必须是 APIRequest
的示例,或者实现了 HTMLRequest
和 RequestInterface
。
另一方面,在加入了 true
和 false
独立类型后,可以将固定返回值的 bool
类型更改为具体的类型。
function alwaysReturnsFalse(): false {} function alwaysReturnsNull(): null {} function alwaysReturnsTrue(): true {}
在过去,我们已经可以通过 string|null
的形式来定义可以为空的参数,而在 PHP 8.2 中,我们将可以直接使用 null
作为一个独立类型。
readonly
类PHP 8.1 添加了只读属性支持,只读类型只能在初始化时被赋值一次,其后的修改会被 PHP 阻止。
而 PHP 8.2 将只读属性延申到只读类中。当一个类被声明为只读类后,它的所有属性都会被自动声明为只读。此外,它还会确保只读类中的所有属性都带有类型声明。
// PHP 8.2 readonly class User { public string $username; public int $uid; } // PHP 8.1 等效写法 class User { public readonly string $username; public readonly int $uid; }
random
扩展纵观 PHP 历史,它支持了各种随机数生成器(RNG)。每种生成器都具有不同的性能、使用场景和安全性。而 PHP 8.2 将所有 RNG 相关的功能重构成名为 random
新扩展。
random
扩展与现有的 API 保持兼容,同时提供相同的功能,因此 rand
mt_rand
random_bytes
random_int
等函数可以继续工作,没有任何变化。但 random
扩展提供了全新的面向对象的 API 来生成具有模块化架构的随机数,令模拟 RNG 和提供新的 RNG 变得更加容易,使测试项目更加安全且便利。
PHP 8.2 允许在 Trait 中定义常量。当然,你不能直接访问 Trait,但 Trait 中的常量会在被继承时成为类常量。
trait FooBar { const FOO = 'foo'; private const BAR = 'bar'; final const BAZ = 'baz'; final protected const QUX = 'qux'; } class Test { use FooBar; } echo Test::BAZ; // 'bar'
需要注意的是,Trait 中的常量不可以和其他 Trait 或类中的常量冲突。
PHP 8.2 新增了 #[SensitiveParameter]
参数注解,用于在错误和堆栈信息中隐藏实际值。
接受密码、私钥或其他敏感信息的函数可以使用 #[SensitiveParameter]
来隐藏具体值。如果发生错误或异常,对应的值会被替换为 SensitiveParameterValue
对象。
PHP 的内置函数(如 password_hash
和 password_verify
)已使用 #[SensitiveParameter]
参数注解。
- function passwordHash(string $password) { + function passwordHash(#[\SensitiveParameter] string $password) { debug_print_backtrace(); } passwordHash('hunter2');
array(1) { [0]=> array(4) { ["file"]=> string(38) "..." ["line"]=> int(9) ["function"]=> string(3) "foo" ["args"]=> array(1) { - [0]=> string(38) "hunter2" + [0]=> object(SensitiveParameterValue)#1 (0) {} } } }
ini_parse_quantity
ini_parse_quantity('256M'); // 268435456
curl_upkeep
PHP 8.2 Curl 扩展中的 curl_upkeep
函数触发底层 Curl 库运行必要的任务以保持 Curl 连接处于活动状态。 此函数最常见的用例是通过定期调用 curl_upkeep
函数来保持 HTTP 持久连接 (Keep-Alive)。
openssl_cipher_key_length
在 PHP 8.2 OpenSSL 中,有一个名为 openssl_cipher_key_length
]
true
유형에 대한 지원 추가, null
및 false
를 독립 유형으로 사용할 수 있도록 허용하는 것, DNF 유형에 대한 지원 추가가 포함됩니다. 🎜🎜Disjoint Normal Form(DNF) 유형 지원 - PHP 8.2에서 개발자는 Unionunion
유형(PHP 8.0)과 교차점intersection
유형(PHP 8.0)을 결합할 수 있습니다. 8.1) 이를 통해 보다 정확한 매개변수, 반환 및 속성 유형을 선언할 수 있습니다. 🎜
openssl_cipher_key_length("CHACHA20-POLY1305"); // 32 openssl_cipher_key_length("AES-128-GCM"); // 16 openssl_cipher_key_length("AES-256-GCM"); // 32🎜
(HTMLRequest & RequestInterface) | APIRequest
유형 선언은 $request
가 APIRequest
의 인스턴스이거나 구현되어야 함을 의미합니다. HTMLRequest 및 RequestInterface
. 🎜🎜한편, true
및 false
독립 유형을 추가한 후 고정 반환 값 bool
유형을 특정 유형으로 변경할 수 있습니다. . 🎜class User { public int $uid; } $user = new User(); $user->name = 'Foo';🎜기존에는
string|null
형식으로 null 허용 매개변수를 정의할 수 있었지만, PHP 8.2에서는 null
을 직접 사용할 수 있게 되었습니다. 독립형으로. 🎜readonly
클래스Deprecated: Creation of dynamic property User::$name is deprecated in ... on
random
확장random
이라는 새로운 확장으로 재구성합니다. 🎜🎜random
확장은 동일한 기능을 제공하면서 기존 API와 계속 호환되므로 rand
mt_rand
random_bytes
함수 random_int
와 같은 것은 변경 없이 계속 작동할 수 있습니다. 그러나 random
확장은 모듈식 아키텍처로 난수를 생성하는 새로운 객체 지향 API를 제공하므로 RNG를 더 쉽게 시뮬레이션하고 새로운 RNG를 제공할 수 있으므로 테스트 프로젝트가 더 안전하고 편리해집니다. 🎜#[SensitiveParameter]
매개변수 주석이 추가되었습니다. 🎜🎜비밀번호, 개인 키 또는 기타 민감한 정보를 허용하는 함수는 #[SensitiveParameter]
를 사용하여 특정 값을 숨길 수 있습니다. 오류나 예외가 발생하면 해당 값이 SensitiveParameterValue
개체로 대체됩니다. 🎜🎜 password_hash
및 password_verify
와 같은 PHP의 내장 함수에는 #[SensitiveParameter]
매개변수가 주석으로 추가됩니다. 🎜rrreeerrreeeini_parse_quantity
curl_upkeep
curl_upkeep
함수는 기본 Curl 라이브러리를 트리거하여 Curl 연결을 활성 상태로 유지하는 데 필요한 작업을 실행합니다. 이 함수의 가장 일반적인 사용 사례는 curl_upkeep
함수를 주기적으로 호출하여 HTTP 영구 연결(Keep-Alive)을 유지하는 것입니다. 🎜openssl_cipher_key_length
openssl_cipher_key_length
라는 새로운 함수가 있습니다. OpenSSL 암호화(바이트)입니다. 🎜🎜이 기능을 사용하면 OpenSSL 암호화 작업에 필요한 키 길이를 하드코딩할 필요가 없습니다. 🎜openssl_cipher_key_length("CHACHA20-POLY1305"); // 32 openssl_cipher_key_length("AES-128-GCM"); // 16 openssl_cipher_key_length("AES-256-GCM"); // 32
memory_reset_peak_usage
PHP 8.2 添加了一个名为 memory_reset_peak_usage
的新函数,用于重置由 memory_get_peak_usage
函数返回的峰值内存使用量。
这对于多次调用或迭代一个动作并且需要记录每次调用的峰值内存使用量的应用程序很有帮助。 如果没有 memory_reset_peak_usage
函数重置内存使用情况,memory_get_peak_usage
将会返回整个运行过程中的绝对峰值内存使用情况。
PHP 8.2 也带来了相当一部分弃用。当语法、函数或特性被弃用时,PHP 会发出弃用通知,该通知不会中断 PHP 应用,但会记录到错误日志中。
PHP 8.2 中最值得注意的弃用之一是它弃用了动态声明的类属性。虽然可以忽略错误,但建议在类中声明类属性,加上类型声明就更好了。
class User { public int $uid; } $user = new User(); $user->name = 'Foo';
Deprecated: Creation of dynamic property User::$name is deprecated in ... on
许多古老的 PHP 应用程序很可能会受到此更改的影响,因为它们在扩展时往往不声明类属性,或者随着变化多年来不断发展。
当然了,选择忽略或例外也是存在的:
匿名类及其子类(stdClass
)
具有 __get
和 __set
魔术方法的类
具有 #[AllowDynamicProperties]
注解的类
utf8_encode
和 utf8_decode
函数PHP 8.2 终于弃用这两名字跟实际效果不一致的函数,虽然名为 utf8
但实际上是 Latin 1
(ISO-8859-1)。
大多数使用这些函数的 PHP 项目往往没有意识到这个问题。推荐的替代品包括 mbstring
、iconv
和 intl
扩展以提供更好的功能。
${var}
字符串格式PHP 一直支持使用 foo {$bar}
模式的字符串变量插值,以及将美元符号放在大括号外的替代语法 foo ${bar}
。
在 PHP 8.2 中,将美元符号放在花括号外的替代语法已弃用。
已弃用 | 推荐替代 |
---|---|
Hello ${name} | Hello {$name} |
Hello ${$var} | Hello {$$var} |
此外,PHP 8.2 还弃用了一些部分支持的 callable
模式和 Mbstring 扩展对 Base64、Uuencode、QPrint 和 HTML 实体编码的处理。
위 내용은 PHP 8.2 업데이트! 하나의 문서에서 새로운 기능에 대한 간략한 개요의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!