Heim  >  Artikel  >  Backend-Entwicklung  >  PHP 8.2 aktualisiert! Ein kurzer Überblick über neue Funktionen in einem Artikel

PHP 8.2 aktualisiert! Ein kurzer Überblick über neue Funktionen in einem Artikel

藏色散人
藏色散人nach vorne
2022-12-09 17:02:166705Durchsuche

PHP 8.2-Update-Highlights

Erstellungszeit: 8. Dezember 2022, 22:50 Uhr

Letzte Bearbeitungszeit: 8. Dezember 2022, 23:58 Uhr

Neu gepostet vonPHP 8.2-Update-Highlights: Was ist neu und geändert

.

? PHP 8.2 bringt Verbesserungen des Typsystems, schreibgeschützte readonly-Klassen, Unterstützung für das Ausblenden sensibler Parameter, eine neue zufällige random-Erweiterung und vieles mehr, einschließlich einer vereinfachten und modernisierten PHP-Elementfunktion. readonly 类、敏感参数隐藏支持、新的随机 random 扩展,以及包括简化和现代化 PHP 在内的多项功能。

PHP 8.2 是 PHP 迈入现代化的重要里程碑。除了令人兴奋的新功能和改进之外,PHP 8.2 通过弃用动态属性支持、对 INI 配置值发出警告和修复一系列数组排序和字符串转换的遗留行为。【推荐:PHP视频教程

类型系统改进

PHP 8.2 解决了数个原有类型系统的短处和限制,让 PHP 项目得以拥有更好的类型安全性。这包括添加对 true 类型的支持,并允许将 nullfalse 用作独立类型,同时增加了对 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 的示例,或者实现了 HTMLRequestRequestInterface

另一方面,在加入了 truefalse 独立类型后,可以将固定返回值的 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 变得更加容易,使测试项目更加安全且便利。

Trait 中的常量

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_hashpassword_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 容量 ini_parse_quantity

ini_parse_quantity('256M'); // 268435456

保持 CURL 连接 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

PHP 8.2 ist ein wichtiger Meilenstein in der Modernisierung von PHP. Neben aufregenden neuen Funktionen und Verbesserungen funktioniert PHP 8.2 durch die veraltete Unterstützung dynamischer Eigenschaften, die Ausgabe von Warnungen zu INI-Konfigurationswerten und die Behebung einer Reihe veralteter Verhaltensweisen bei der Array-Sortierung und String-Konvertierung. [Empfohlen: PHP-Video-Tutorial

]

Verbesserungen des Typsystems h2>🎜PHP 8.2 behebt mehrere Mängel und Einschränkungen des ursprünglichen Typsystems und ermöglicht PHP-Projekten eine bessere Typsicherheit. Dazu gehört das Hinzufügen von Unterstützung für true-Typen und die Möglichkeit, dass null und false als unabhängige Typen verwendet werden können, sowie das Hinzufügen von Unterstützung für DNF-Typen. 🎜
🎜Disjoint Normal Form (DNF)-Typunterstützung – In PHP 8.2 können Entwickler den Union-Typ union (PHP 8.0) und den Intersection-Typ intersection (PHP) kombinieren 8.1), was wiederum die Deklaration präziserer Parameter-, Rückgabe- und Eigenschaftstypen ermöglicht. 🎜
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-Typdeklaration bedeutet, dass $request eine Instanz von APIRequest sein muss HTMLRequest und RequestInterface. 🎜🎜Andererseits kann nach dem Hinzufügen der unabhängigen Typen true und false der Typ mit festem Rückgabewert bool in einen bestimmten Typ geändert werden . 🎜
class User {
    public int $uid;
}

$user = new User();
$user->name = 'Foo';
🎜In der Vergangenheit konnten wir nullfähige Parameter in der Form string|null definieren, aber in PHP 8.2 können wir null direkt verwenden als unabhängiger Typ. 🎜

Schreibgeschützte readonly-Klasse

🎜PHP 8.1 bietet Unterstützung für schreibgeschützte Eigenschaften. Schreibgeschützte Typen können nur einmal während der Initialisierung zugewiesen werden, und nachfolgende Änderungen werden blockiert PHP. 🎜🎜Und PHP 8.2 erweitert das schreibgeschützte Attribut auf die schreibgeschützte Klasse. Wenn eine Klasse als schreibgeschützt deklariert wird, werden alle ihre Eigenschaften automatisch als schreibgeschützt deklariert. Darüber hinaus wird sichergestellt, dass alle Eigenschaften in schreibgeschützten Klassen über Typdeklarationen verfügen. 🎜
Deprecated: Creation of dynamic property User::$name is deprecated in ... on

Neue zufällige random-Erweiterung

🎜Im Laufe der Geschichte von PHP wurden verschiedene Zufallszahlengeneratoren (RNG) unterstützt. Jeder Generator verfügt über unterschiedliche Leistung, Nutzungsszenarien und Sicherheit. PHP 8.2 strukturiert alle RNG-bezogenen Funktionen in eine neue Erweiterung namens random um. 🎜🎜random-Erweiterung bleibt mit der vorhandenen API kompatibel und bietet gleichzeitig die gleiche Funktionalität, sodass rand mt_rand random_bytes Funktionen wie z da random_int ohne Änderungen weiterarbeiten kann. Aber die random-Erweiterung bietet eine neue objektorientierte API zum Generieren von Zufallszahlen mit einer modularen Architektur, die es einfacher macht, RNGs zu simulieren und neue RNGs bereitzustellen, wodurch Testprojekte sicherer und bequemer werden. 🎜

Konstanten in Merkmalen

🎜PHP 8.2 ermöglicht die Definition von Konstanten in Merkmalen. Natürlich können Sie nicht direkt auf Traits zugreifen, aber Konstanten in Traits werden durch Vererbung zu Klassenkonstanten. 🎜rrreee🎜Es ist zu beachten, dass Konstanten in Traits nicht mit Konstanten in anderen Traits oder Klassen in Konflikt geraten können. 🎜

Unterstützt das Ausblenden vertraulicher Parameter

🎜PHP 8.2 fügt die Parameteranmerkung #[SensitiveParameter] zum Ausblenden tatsächlicher Werte in Fehlern und Stapelinformationen hinzu. 🎜🎜Funktionen, die Passwörter, private Schlüssel oder andere vertrauliche Informationen akzeptieren, können #[SensitiveParameter] verwenden, um den spezifischen Wert auszublenden. Wenn ein Fehler oder eine Ausnahme auftritt, wird der entsprechende Wert durch ein SensitiveParameterValue-Objekt ersetzt. 🎜🎜PHPs integrierte Funktionen wie password_hash und password_verify sind mit #[SensitiveParameter]-Parametern annotiert. 🎜rrreeerrree

Neue Funktionen und Klassen

Ini-Kapazität analysieren ini_parse_quantity

rrreee

CURL-Verbindung beibehalten curl_upkeep

🎜Die Funktion curl_upkeep in der PHP 8.2 Curl-Erweiterung veranlasst die zugrunde liegende Curl-Bibliothek, die notwendigen Aufgaben auszuführen, um die Curl-Verbindung aktiv zu halten. Der häufigste Anwendungsfall für diese Funktion besteht darin, eine dauerhafte HTTP-Verbindung (Keep-Alive) aufrechtzuerhalten, indem die Funktion curl_upkeep regelmäßig aufgerufen wird. 🎜

Verschlüsselungsschlüssellänge abrufen openssl_cipher_key_length

🎜In PHP 8.2 OpenSSL gibt es eine neue Funktion namens openssl_cipher_key_length, die alle unterstützten Schlüssellängen zurückgibt OpenSSL-Verschlüsselung, in Bytes. 🎜🎜Diese Funktion macht es überflüssig, die für OpenSSL-Kryptografieoperationen erforderliche Schlüssellänge fest zu codieren. 🎜
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 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_encodeutf8_decode 函数

PHP 8.2 终于弃用这两名字跟实际效果不一致的函数,虽然名为 utf8 但实际上是 Latin 1 (ISO-8859-1)。

大多数使用这些函数的 PHP 项目往往没有意识到这个问题。推荐的替代品包括 mbstringiconvintl 扩展以提供更好的功能。

弃用 ${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 实体编码的处理。

Das obige ist der detaillierte Inhalt vonPHP 8.2 aktualisiert! Ein kurzer Überblick über neue Funktionen in einem Artikel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:learnku.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen