Heim >Backend-Entwicklung >PHP-Tutorial >Zusammenstellung neuer Features von PHP5.5 bis PHP7.2

Zusammenstellung neuer Features von PHP5.5 bis PHP7.2

小云云
小云云Original
2018-03-31 11:20:312378Durchsuche

In diesem Artikel werden hauptsächlich die neuen Funktionen von PHP5.5 bis PHP7.2 vorgestellt, damit jeder jede Version von PHP verstehen kann, und ich hoffe, dass er allen helfen kann.

Portiert von PHP 5.5.x auf PHP 5.6.x

Neue Funktionen

Verwenden Sie Ausdrücke, um Konstanten zu definieren

  • Before In In der PHP-Version müssen Sie statische Werte verwenden, um Konstanten zu definieren, Eigenschaften zu deklarieren und Standardwerte für Funktionsparameter anzugeben. Sie können jetzt numerische Ausdrücke wie Zahlen, Zeichenfolgenliterale und andere Konstanten verwenden, um Konstanten zu definieren, Eigenschaften zu deklarieren und Standardwerte für Funktionsparameter festzulegen.

<?phpconst ONE = 1;const TWO = ONE * 2;class C {
    const THREE = TWO + 1;    const ONE_THIRD = ONE / self::THREE;    const SENTENCE = &#39;The value of THREE is &#39;.self::THREE;
}
  • Konstanten vom Typ Array können jetzt über das Schlüsselwort const definiert werden.

<?phpconst ARR = [&#39;a&#39;, &#39;b&#39;];echo ARR[0];

Verwenden Sie den...-Operator, um eine Parameterfunktion variabler Länge zu definieren

  • Sie können jetzt den...-Operator verwenden ohne sich auf func_get_args() zu verlassen, um eine Parameterfunktion mit variabler Länge zu implementieren.

<?php
function f($req, $opt = null, ...$params) {
    // $params 是一个包含了剩余参数的数组
    printf(&#39;$req: %d; $opt: %d; number of params: %d&#39;."\n",           $req, $opt, count($params));
}
f(1);
f(1, 2);
f(1, 2, 3);
f(1, 2, 3, 4);
?>

Die obige Routine gibt Folgendes aus:

$req: 1; $opt: 0; number of params: 0
$req: 1; $opt: 2; number of params: 0
$req: 1; $opt: 2; number of params: 1
$req: 1; $opt: 2; number of params: 2

Verwenden Sie... den Operator zur Parametererweiterung

  • Verwenden Sie beim Aufrufen einer Funktion den ...-Operator, um Arrays und durchlaufbare Objekte in Funktionsparameter zu erweitern. In anderen Programmiersprachen wie Ruby wird dies als Verkettungsoperator bezeichnet.

<?phpfunction add($a, $b, $c) {
    return $a + $b + $c;
}$operators = [2, 3];echo add(1, ...$operators);?>

Die obige Routine gibt Folgendes aus:

6

Verwenden Sie die Funktion und verwenden Sie const

  • Verwenden Sie den Operator Has wurde erweitert, um den Import externer Funktionen und Konstanten in Klassen zu unterstützen. Die entsprechenden Strukturen sind use function und use const.

<?phpnamespace Name\Space {    const FOO = 42;    function f() { echo __FUNCTION__."\n"; }
}namespace {    use const Name\Space\FOO;    use function Name\Space\f;    echo FOO."\n";
    f();
}?>

Die obige Routine gibt Folgendes aus:

42
Name\Space\f

Verwenden Sie hash_equals(), um Zeichenfolgen zu vergleichen, um Timing-Angriffe zu vermeiden

Ab PHP 5.6 . und strenges Modell. Die folgenden Typparameter sind jetzt verfügbar (entweder im erzwungenen oder strikten Modus): string, int, float und bool.

Die obige Routine gibt Folgendes aus:
  • Deklaration des Rückgabewerttyps

<?php// Coercive modefunction sumOfInts(int ...$ints){
    return array_sum($ints);
}
var_dump(sumOfInts(2, &#39;3&#39;, 4.1));
PHP 7 hat Unterstützung hinzugefügt für Rückgabetypdeklarationen. Ähnlich wie die Parametertypdeklaration gibt die Rückgabetypdeklaration den Typ des Rückgabewerts der Funktion an. Die verfügbaren Typen sind dieselben wie die in der Parameterdeklaration verfügbaren.

int(9)

Null-Koaleszenzoperator
  • Aufgrund der großen Anzahl gleichzeitiger Verwendung von ternären Ausdrücken und isset() im täglichen Gebrauch haben wir Der Syntaxzucker des Null-Koaleszenzoperators (??) wurde hinzugefügt. Wenn die Variable existiert und nicht NULL ist, gibt sie ihren eigenen Wert zurück, andernfalls gibt sie ihren zweiten Operanden zurück.
<?phpfunction arraysSum(array ...$arrays): array{
    return array_map(function(array $array): int {
        return array_sum($array);
    }, $arrays);
}

Raumschiff-Operator (kombinierte Vergleichsoperatoren)
  • Der Raumschiff-Operator wird verwendet, um zwei Ausdrücke zu vergleichen. Es gibt jeweils -1, 0 oder 1 zurück, wenn
b. Das Vergleichsprinzip folgt den regulären Vergleichsregeln von PHP.
<?php
// Fetches the value of $_GET[&#39;user&#39;] and returns &#39;nobody&#39; if it does not exist.$username = $_GET[&#39;user&#39;] ?? &#39;nobody&#39;;// This is equivalent to:$username = isset($_GET[&#39;user&#39;]) ? $_GET[&#39;user&#39;] : &#39;nobody&#39;;// Coalesces can be chained: this will return the first defined value out of $_GET[&#39;user&#39;], $_POST[&#39;user&#39;], and &#39;nobody&#39;.$username = $_GET[&#39;user&#39;] ?? $_POST[&#39;user&#39;] ?? &#39;nobody&#39;;
?>

  • Konstanten-Arrays über define() definieren

    Konstanten vom Typ Array können jetzt über define() definiert werden. In PHP5.6 kann es nur über const definiert werden.
<?php// 整数echo 1 <=> '1'; // 0echo 1 <=> 2; // -1echo 2 <=> 1; // 1// 浮点数echo '1.50' <=> 1.5; // 0echo 1.5 <=> 2.5; // -1echo 2.5 <=> 1.5; // 1// 字符串echo "a" <=> "a"; // 0echo "a" <=> "b"; // -1echo "b" <=> "a"; // 1?>

Closure::call()
  • Closure::call() hat jetzt eine bessere Leistung, eine kürzere und sauberere Ausführung. Bind a Methode zum Abschluss des Objekts hinzufügen und aufrufen.
define('ANIMALS', [    'dog',    'cat',    'bird']);
echo ANIMALS[1]; // 输出 "cat"

Die obige Routine gibt Folgendes aus:
  • Gruppenverwendungsanweisung

<?phpclass A {private $x = 1;}// PHP 7 之前版本的代码$getXCB = function() {return $this->x;};$getX = $getXCB->bindTo(new A, 'A'); // 中间层闭包echo $getX();// PHP 7+ 及更高版本的代码$getX = function() {return $this->x;};echo $getX->call(new A);
Importiert aus demselben Namespace Klassen, Funktionen und Konstanten können jetzt alle auf einmal mit einer einzigen Use-Anweisung importiert werden.

1

Generatoren können Ausdrücke zurückgeben
  • Diese Funktion baut auf der Generatorfunktion auf, die in der PHP 5.5-Version eingeführt wurde. Sie können einen Ausdruck zurückgeben (aber nicht die Rückgabe eines Referenzwerts), indem Sie die Rückgabesyntax in einer Generatorfunktion verwenden. Sie können den Rückgabewert des Generators erhalten, indem Sie die Methode Generator::getReturn() aufrufen Diese Methode kann nur beim Generieren verwendet werden. Wird einmal aufgerufen, nachdem der Prozessor die Generierung der Arbeit abgeschlossen hat.
<?php// PHP 7 之前的代码use some\namespace\ClassA;use some\namespace\ClassB;use some\namespace\ClassC as C;use function some\namespace\fn_a;use function some\namespace\fn_b;use function some\namespace\fn_c;use const some\namespace\ConstA;use const some\namespace\ConstB;use const some\namespace\ConstC;// PHP 7+ 及更高版本的代码use some\namespace\{ClassA, ClassB, ClassC as C};use function some\namespace\{fn_a, fn_b, fn_c};use const some\namespace\{ConstA, ConstB, ConstC};
?>

Ganzzahldivisionsfunktion intp()

  • Portiert von PHP 7.0.x nach PHP 7.1.x

    Neue Funktionen
Nullable-Typen


Die Typen von Parametern und Rückgabewerten können jetzt nullbar sein, indem vor dem Typ ein Fragezeichen hinzugefügt wird. Wenn diese Funktion aktiviert ist, sind die übergebenen Parameter oder das von der Funktion zurückgegebene Ergebnis entweder vom angegebenen Typ oder null .

Die obige Routine gibt Folgendes aus:
  • Void-Funktion

<?phpfunction testReturn(): ?string{
    return &#39;elePHPant&#39;;
}
var_dump(testReturn());function testReturn(): ?string{
    return null;
}
var_dump(testReturn());function test(?string $name){
    var_dump($name);
}
test(&#39;elePHPant&#39;);
test(null);
test();
Ein neuer Rückgabewert vom Typ void wird eingeführt. Methoden, deren Rückgabewerte vom Typ void deklariert sind, lassen die Return-Anweisung entweder ganz weg oder verwenden eine leere Return-Anweisung. NULL ist kein zulässiger Rückgabewert für Void-Funktionen.

string(10) "elePHPant"
NULL
string(10) "elePHPant"
NULL
Uncaught Error: Too few arguments to function test(), 0 passed in...

Die obige Routine gibt Folgendes aus:
  • Symmetrische Array-Destrukturierung

<?phpfunction swap(&$left, &$right) : void{
    if ($left === $right) {        return;
    }    $tmp = $left;    $left = $right;    $right = $tmp;
}$a = 1;$b = 2;
var_dump(swap($a, $b), $a, $b);
Kurze Array-Syntax ([ ]) ist jetzt eine Alternative zur list()-Syntax und kann verwendet werden, um den Wert eines Arrays einer Variablen zuzuweisen (einschließlich in foreach).

<?php$data = [
    [1, &#39;Tom&#39;],
    [2, &#39;Fred&#39;],
];// list() stylelist($id1, $name1) = $data[0];// [] style[$id1, $name1] = $data[0];// list() styleforeach ($data as list($id, $name)) {    // logic here with $id and $name}// [] styleforeach ($data as [$id, $name]) {    // logic here with $id and $name}

类常量可见性

  • 现在起支持设置类常量的可见性。

<?php
class ConstDemo
{    const PUBLIC_CONST_A = 1;    public const PUBLIC_CONST_B = 2;    protected const PROTECTED_CONST = 3;    private const PRIVATE_CONST = 4;
}

iterable 伪类

  • 现在引入了一个新的被称为iterable的伪类 (与callable类似)。 这可以被用在参数或者返回值类型中,它代表接受数组或者实现了Traversable接口的对象。 至于子类,当用作参数时,子类可以收紧父类的iterable类型到array 或一个实现了Traversable的对象。对于返回值,子类可以拓宽父类的 array或对象返回值类型到iterable。

<?phpfunction iterator(iterable $iter) : iterable{
    foreach ($iter as $val) {        //
    }
}

多异常捕获处理

  • 一个catch语句块现在可以通过管道字符(|)来实现多个异常的捕获。 这对于需要同时处理来自不同类的不同异常时很有用。

<?phptry {    // some code} catch (FirstException | SecondException $e) {    // handle first and second exceptions}

list()现在支持键名

  • 现在list()和它的新的[]语法支持在它内部去指定键名。这意味着它可以将任意类型的数组 都赋值给一些变量(与短数组语法类似)

<?php$data = [
    ["id" => 1, "name" => 'Tom'],
    ["id" => 2, "name" => 'Fred'],
];// list() stylelist("id" => $id1, "name" => $name1) = $data[0];// [] style["id" => $id1, "name" => $name1] = $data[0];// list() styleforeach ($data as list("id" => $id, "name" => $name)) {    // logic here with $id and $name}// [] styleforeach ($data as ["id" => $id, "name" => $name]) {    // logic here with $id and $name}

从PHP 7.1.x 移植到 PHP 7.2.x

新特性

新的对象类型

  • 这种新的对象类型, object, 引进了可用于逆变(contravariant)参数输入和协变(covariant)返回任何对象类型。

<?phpfunction test(object $obj) : object{
    return new SplQueue();
}
test(new StdClass());

允许重写抽象方法(Abstract method)

  • 当一个抽象类继承于另外一个抽象类的时候,继承后的抽象类可以重写被继承的抽象类的抽象方法。

abstract class A{
    abstract function test(string $s);}abstract class B extends A{
    // overridden - still maintaining contravariance for parameters and covariance for return
    abstract function test($s) : int;}

扩展了参数类型

  • 重写方法和接口实现的参数类型现在可以省略了。不过这仍然是符合LSP,因为现在这种参数类型是逆变的。

interface A{
    public function Test(array $input);}class B implements A{
    public function Test($input){} // type omitted for $input}

允许分组命名空间的尾部逗号

  • 命名空间可以在PHP 7中使用尾随逗号进行分组引入。

use Foo\Bar\{    Foo,    Bar,    Baz,
};

http://php.net/manual/zh/appendices.php

从PHP 5.5.x 移植到 PHP 5.6.x

新特性

使用表达式定义常量

  • 在之前的 PHP 版本中, 必须使用静态值来定义常量,声明属性以及指定函数参数默认值。 现在你可以使用包括数值、字符串字面量以及其他常量在内的数值表达式来 定义常量、声明属性以及设置函数参数默认值。

<?phpconst ONE = 1;const TWO = ONE * 2;class C {
    const THREE = TWO + 1;    const ONE_THIRD = ONE / self::THREE;    const SENTENCE = &#39;The value of THREE is &#39;.self::THREE;
}
  • 现在可以通过 const 关键字来定义类型为 array 的常量。

<?phpconst ARR = [&#39;a&#39;, &#39;b&#39;];echo ARR[0];

使用 ... 运算符定义变长参数函数

  • 现在可以不依赖 func_get_args(), 使用 … 运算符 来实现 变长参数函数。

<?php
function f($req, $opt = null, ...$params) {
    // $params 是一个包含了剩余参数的数组
    printf(&#39;$req: %d; $opt: %d; number of params: %d&#39;."\n",           $req, $opt, count($params));
}
f(1);
f(1, 2);
f(1, 2, 3);
f(1, 2, 3, 4);
?>

以上例程会输出:

$req: 1; $opt: 0; number of params: 0
$req: 1; $opt: 2; number of params: 0
$req: 1; $opt: 2; number of params: 1
$req: 1; $opt: 2; number of params: 2

使用 ... 运算符进行参数展开

  • 在调用函数的时候,使用 … 运算符, 将 数组 和 可遍历 对象展开为函数参数。 在其他编程语言,比如 Ruby中,这被称为连接运算符。

<?phpfunction add($a, $b, $c) {
    return $a + $b + $c;
}$operators = [2, 3];echo add(1, ...$operators);?>

以上例程会输出:

6

use function 以及 use const

  • use 运算符 被进行了扩展以支持在类中导入外部的函数和常量。 对应的结构为 use function 和 use const。

<?phpnamespace Name\Space {    const FOO = 42;    function f() { echo __FUNCTION__."\n"; }
}namespace {    use const Name\Space\FOO;    use function Name\Space\f;    echo FOO."\n";
    f();
}?>

以上例程会输出:

42
Name\Space\f

使用 hash_equals() 比较字符串避免时序攻击

从PHP 5.6.x 移植到 PHP 7.0.x

新特性

标量类型声明

  • 标量类型声明 有两种模式: 强制 (默认) 和 严格模式。 现在可以使用下列类型参数(无论用强制模式还是严格模式): 字符串(string), 整数 (int), 浮点数 (float), 以及布尔值 (bool)。

<?php// Coercive modefunction sumOfInts(int ...$ints){
    return array_sum($ints);
}
var_dump(sumOfInts(2, &#39;3&#39;, 4.1));

以上例程会输出:

int(9)

返回值类型声明

  • PHP 7 增加了对返回类型声明的支持。 类似于参数类型声明,返回类型声明指明了函数返回值的类型。可用的类型与参数声明中可用的类型相同。

<?phpfunction arraysSum(array ...$arrays): array{
    return array_map(function(array $array): int {
        return array_sum($array);
    }, $arrays);
}

null合并运算符

  • 由于日常使用中存在大量同时使用三元表达式和 isset()的情况, 我们添加了null合并运算符 (??) 这个语法糖。如果变量存在且值不为NULL, 它就会返回自身的值,否则返回它的第二个操作数。

<?php
// Fetches the value of $_GET[&#39;user&#39;] and returns &#39;nobody&#39; if it does not exist.$username = $_GET[&#39;user&#39;] ?? &#39;nobody&#39;;// This is equivalent to:$username = isset($_GET[&#39;user&#39;]) ? $_GET[&#39;user&#39;] : &#39;nobody&#39;;// Coalesces can be chained: this will return the first defined value out of $_GET[&#39;user&#39;], $_POST[&#39;user&#39;], and &#39;nobody&#39;.$username = $_GET[&#39;user&#39;] ?? $_POST[&#39;user&#39;] ?? &#39;nobody&#39;;
?>

太空船操作符(组合比较符)

  • 太空船操作符用于比较两个表达式。当

    b时它分别返回-1、0或1。 比较的原则是沿用 PHP 的常规比较规则进行的。

<?php// 整数echo 1 <=> '1'; // 0echo 1 <=> 2; // -1echo 2 <=> 1; // 1// 浮点数echo '1.50' <=> 1.5; // 0echo 1.5 <=> 2.5; // -1echo 2.5 <=> 1.5; // 1// 字符串echo "a" <=> "a"; // 0echo "a" <=> "b"; // -1echo "b" <=> "a"; // 1?>

通过 define() 定义常量数组

  • Array 类型的常量现在可以通过 define() 来定义。在 PHP5.6 中仅能通过 const 定义。

define('ANIMALS', [    'dog',    'cat',    'bird']);
echo ANIMALS[1]; // 输出 "cat"

Closure::call()

  • Closure::call() 现在有着更好的性能,简短干练的暂时绑定一个方法到对象上闭包并调用它。

<?phpclass A {private $x = 1;}// PHP 7 之前版本的代码$getXCB = function() {return $this->x;};$getX = $getXCB->bindTo(new A, 'A'); // 中间层闭包echo $getX();// PHP 7+ 及更高版本的代码$getX = function() {return $this->x;};echo $getX->call(new A);

以上例程会输出:

1

分组 use 声明

  • 从同一 namespace 导入的类、函数和常量现在可以通过单个 use 语句 一次性导入了。

<?php// PHP 7 之前的代码use some\namespace\ClassA;use some\namespace\ClassB;use some\namespace\ClassC as C;use function some\namespace\fn_a;use function some\namespace\fn_b;use function some\namespace\fn_c;use const some\namespace\ConstA;use const some\namespace\ConstB;use const some\namespace\ConstC;// PHP 7+ 及更高版本的代码use some\namespace\{ClassA, ClassB, ClassC as C};use function some\namespace\{fn_a, fn_b, fn_c};use const some\namespace\{ConstA, ConstB, ConstC};
?>

生成器可以返回表达式

  • 此特性基于 PHP 5.5 版本中引入的生成器特性构建的。 它允许在生成器函数中通过使用 return 语法来返回一个表达式 (但是不允许返回引用值), 可以通过调用 Generator::getReturn() 方法来获取生成器的返回值, 但是这个方法只能在生成器完成产生工作以后调用一次。

整数除法函数 intp()


从PHP 7.0.x 移植到 PHP 7.1.x

新特性

可为空(Nullable)类型

  • 参数以及返回值的类型现在可以通过在类型前加上一个问号使之允许为空。 当启用这个特性时,传入的参数或者函数返回的结果要么是给定的类型,要么是 null 。

<?phpfunction testReturn(): ?string{
    return &#39;elePHPant&#39;;
}
var_dump(testReturn());function testReturn(): ?string{
    return null;
}
var_dump(testReturn());function test(?string $name){
    var_dump($name);
}
test(&#39;elePHPant&#39;);
test(null);
test();

以上例程会输出:

string(10) "elePHPant"
NULL
string(10) "elePHPant"
NULL
Uncaught Error: Too few arguments to function test(), 0 passed in...

Void 函数

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

<?phpfunction swap(&$left, &$right) : void{
    if ($left === $right) {        return;
    }    $tmp = $left;    $left = $right;    $right = $tmp;
}$a = 1;$b = 2;
var_dump(swap($a, $b), $a, $b);

以上例程会输出:

null
int(2)
int(1)

Symmetric array destructuring

  • 短数组语法([])现在作为list()语法的一个备选项,可以用于将数组的值赋给一些变量(包括在foreach中)。

<?php$data = [
    [1, &#39;Tom&#39;],
    [2, &#39;Fred&#39;],
];// list() stylelist($id1, $name1) = $data[0];// [] style[$id1, $name1] = $data[0];// list() styleforeach ($data as list($id, $name)) {    // logic here with $id and $name}// [] styleforeach ($data as [$id, $name]) {    // logic here with $id and $name}

类常量可见性

  • 现在起支持设置类常量的可见性。

<?php
class ConstDemo
{    const PUBLIC_CONST_A = 1;    public const PUBLIC_CONST_B = 2;    protected const PROTECTED_CONST = 3;    private const PRIVATE_CONST = 4;
}

iterable 伪类

  • 现在引入了一个新的被称为iterable的伪类 (与callable类似)。 这可以被用在参数或者返回值类型中,它代表接受数组或者实现了Traversable接口的对象。 至于子类,当用作参数时,子类可以收紧父类的iterable类型到array 或一个实现了Traversable的对象。对于返回值,子类可以拓宽父类的 array或对象返回值类型到iterable。

<?phpfunction iterator(iterable $iter) : iterable{
    foreach ($iter as $val) {        //
    }
}

多异常捕获处理

  • 一个catch语句块现在可以通过管道字符(|)来实现多个异常的捕获。 这对于需要同时处理来自不同类的不同异常时很有用。

<?phptry {    // some code} catch (FirstException | SecondException $e) {    // handle first and second exceptions}

list()现在支持键名

  • 现在list()和它的新的[]语法支持在它内部去指定键名。这意味着它可以将任意类型的数组 都赋值给一些变量(与短数组语法类似)

<?php$data = [
    ["id" => 1, "name" => 'Tom'],
    ["id" => 2, "name" => 'Fred'],
];// list() stylelist("id" => $id1, "name" => $name1) = $data[0];// [] style["id" => $id1, "name" => $name1] = $data[0];// list() styleforeach ($data as list("id" => $id, "name" => $name)) {    // logic here with $id and $name}// [] styleforeach ($data as ["id" => $id, "name" => $name]) {    // logic here with $id and $name}

从PHP 7.1.x 移植到 PHP 7.2.x

新特性

新的对象类型

  • 这种新的对象类型, object, 引进了可用于逆变(contravariant)参数输入和协变(covariant)返回任何对象类型。

<?phpfunction test(object $obj) : object{
    return new SplQueue();
}
test(new StdClass());

允许重写抽象方法(Abstract method)

  • 当一个抽象类继承于另外一个抽象类的时候,继承后的抽象类可以重写被继承的抽象类的抽象方法。

abstract class A{
    abstract function test(string $s);}abstract class B extends A{
    // overridden - still maintaining contravariance for parameters and covariance for return
    abstract function test($s) : int;}

扩展了参数类型

  • 重写方法和接口实现的参数类型现在可以省略了。不过这仍然是符合LSP,因为现在这种参数类型是逆变的。

interface A{
    public function Test(array $input);}class B implements A{
    public function Test($input){} // type omitted for $input}

允许分组命名空间的尾部逗号

  • 命名空间可以在PHP 7中使用尾随逗号进行分组引入。

use Foo\Bar\{    Foo,    Bar,    Baz,
};

相关推荐:

PHP5各个版本的新功能和新特性总结

Das obige ist der detaillierte Inhalt vonZusammenstellung neuer Features von PHP5.5 bis PHP7.2. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn