PHP5.5에서 PHP7.2까지 새로운 기능 컴파일
이 기사는 주로 PHP5.5에서 PHP7.2까지의 새로운 기능을 공유하므로 모든 사람이 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 = 'The value of THREE is '.self::THREE; }
이제 const 키워드를 통해 배열 유형의 상수를 정의할 수 있습니다.
<?phpconst ARR = ['a', 'b'];echo ARR[0];
... 연산자를 사용하여 가변 길이 매개변수 함수 정의
이제 ... 연산자를 사용하여 func_get_args()에 의존하지 않고 가변 길이 매개변수 함수를 구현할 수 있습니다.
<?php function f($req, $opt = null, ...$params) { // $params 是一个包含了剩余参数的数组 printf('$req: %d; $opt: %d; number of params: %d'."\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에서 이식됨 스칼라 유형 선언에는 필수(기본값) 모드와 엄격 모드의 두 가지 모드가 있습니다. 이제 다음 유형 매개변수를 사용할 수 있습니다(강제 모드 또는 엄격 모드): string, int, float 및 bool.
<?php// Coercive modefunction sumOfInts(int ...$ints){ return array_sum($ints); } var_dump(sumOfInts(2, '3', 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['user'] and returns 'nobody' if it does not exist.$username = $_GET['user'] ?? 'nobody';// This is equivalent to:$username = isset($_GET['user']) ? $_GET['user'] : 'nobody';// Coalesces can be chained: this will return the first defined value out of $_GET['user'], $_POST['user'], and 'nobody'.$username = $_GET['user'] ?? $_POST['user'] ?? 'nobody'; ?>
우주선 연산자(조합 비교 연산자)
우주선 연산자는 두 식을 비교하는 데 사용됩니다.
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()을 통해 상수 배열 정의
-
이제 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
- 그룹 사용 문
- 이제 동일한 네임스페이스에서 가져온 클래스, 함수 및 상수를 단일 사용 문을 통해 한 번에 가져올 수 있습니다.
<?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 버전에 도입된 생성기 기능을 기반으로 합니다. 생성기 함수의 반환 구문을 사용하여 표현식을 반환할 수 있지만 참조 값의 반환은 허용되지 않습니다. Generator::getReturn() 메서드를 호출하여 생성기의 반환 값을 얻을 수 있습니다. 이 메서드는 생성할 때만 사용할 수 있습니다. 프로세서가 작업 생성을 마친 후 한 번 호출됩니다.
정수 나누기 함수 intp()
- PHP 7.0.x에서 PHP 7.1.x로 이식새로운 기능
이제 매개변수 유형과 반환 값을 전달할 수 있습니다. 추가 유형 앞에 물음표를 추가하면 null이 될 수 있습니다. 이 기능이 활성화되면 전달된 매개변수 또는 함수에서 반환된 결과는 지정된 유형이거나 null 입니다.
<?phpfunction testReturn(): ?string{ return 'elePHPant'; } var_dump(testReturn());function testReturn(): ?string{ return null; } var_dump(testReturn());function test(?string $name){ var_dump($name); } test('elePHPant'); 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 문을 사용합니다. NULL은 void 함수에 대한 합법적인 반환 값이 아닙니다.
<?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, 'Tom'], [2, 'Fred'], ];// 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 = 'The value of THREE is '.self::THREE; }
现在可以通过 const 关键字来定义类型为 array 的常量。
<?phpconst ARR = ['a', 'b'];echo ARR[0];
使用 ... 运算符定义变长参数函数
现在可以不依赖 func_get_args(), 使用 … 运算符 来实现 变长参数函数。
<?php function f($req, $opt = null, ...$params) { // $params 是一个包含了剩余参数的数组 printf('$req: %d; $opt: %d; number of params: %d'."\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, '3', 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['user'] and returns 'nobody' if it does not exist.$username = $_GET['user'] ?? 'nobody';// This is equivalent to:$username = isset($_GET['user']) ? $_GET['user'] : 'nobody';// Coalesces can be chained: this will return the first defined value out of $_GET['user'], $_POST['user'], and 'nobody'.$username = $_GET['user'] ?? $_POST['user'] ?? 'nobody'; ?>
太空船操作符(组合比较符)
-
太空船操作符用于比较两个表达式。当
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 'elePHPant'; } var_dump(testReturn());function testReturn(): ?string{ return null; } var_dump(testReturn());function test(?string $name){ var_dump($name); } test('elePHPant'); 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, 'Tom'], [2, 'Fred'], ];// 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.5에서 PHP7.2까지 새로운 기능 컴파일의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

PHP의 마법 방법은 무엇입니까? PHP의 마법 방법은 다음과 같습니다. 1. \ _ \ _ Construct, 객체를 초기화하는 데 사용됩니다. 2. \ _ \ _ 파괴, 자원을 정리하는 데 사용됩니다. 3. \ _ \ _ 호출, 존재하지 않는 메소드 호출을 처리하십시오. 4. \ _ \ _ get, 동적 속성 액세스를 구현하십시오. 5. \ _ \ _ Set, 동적 속성 설정을 구현하십시오. 이러한 방법은 특정 상황에서 자동으로 호출되어 코드 유연성과 효율성을 향상시킵니다.
