php7.1 새로운 기능
1. Null 가능 유형
유형 이름(null) 앞에 물음표(?
)를 추가하여 매개변수 및 반환 값의 유형 선언을 null로 표시할 수 있습니다. ). 함수 매개변수 또는 반환 값의 유형이 지정된 유형이거나 null임을 나타냅니다. ?
)来标记为空(null)。表明函数参数或者返回值的类型要么为指定类型,要么为 null。
看下例子:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
打印输出:
$ php php71.phpstring(6) "yangyi"NULL PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to function testReturn(), 0 passed in php71.php on line 22 and exactly 1 expected in php71.php:14Stack trace:#0 php71.php(22): testReturn()#1 {main} thrown in php71.php on line 14
如上如:第三个报了一个致命的错误。
再来看下,函数返回值是Nullable
的情况:
function testReturn3() : ?string{ //return "abc"; //return null;} var_dump(testReturn3());
如果加了?
要么返回 string ,要么返回null。不能啥也不返还。会报错。
2.void返回类型
PHP7.0 添加了指定函数返回类型的特性,但是返回类型却不能指定为 void,7.1 的这个特性算是一个补充。定义返回类型为 void
的函数不能有返回值,即使返回 null 也不行:
function testReturn4() : void{ //1. 要么啥都不返还 ok //2. 要么只return; ok //return; //3. return null 也会报错 //return null; //4. return 4 会报错 //return 4;}
Fatal error: A void function must not return a value in /php71.php on line 70
还有就是,void 只能用于返回值,不能用于参数中。比如下面的会报错:
function testReturn6(void $a) : void{} var_dump(testReturn6());
PHP Fatal error: void cannot be used as a parameter type in php71.php on line 73
如果在类的继承中,申明为void返回类型的方法,子类要是继承重写,也只能返回void, 否则会触发错误:
<?php class Foo{ public function bar(): void { } }class Foobar extends Foo{ // 覆盖失败 public function bar(): array { // Fatal error: Declaration of Foobar::bar() must be compatible with Foo::bar(): void } }
所以,你必须这样,就不会报错:
class Foo{ public $a; public function bar(): void { $this->a = 2; } }class Foobar extends Foo{ // 覆盖成功 public function bar(): void { $this->a = 3; } }
3.list 的方括号([]
)简写以及增加指定key
可以用list 来快速遍历得到数组里面的值。现在可以用[]
简写了。
$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}
此外,此次更新的list,针对索引数组,还可以指定 key,这个升级非常棒,非常方便。
$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}
在这个功能没有之前,我们一般会用while
+ each
的方式来用list
遍历索引数组:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];while (list($id, name) = each($data)) { echo "$key => $val\n"; }
注意:PHP 7.2 中已经将 each 函数移除了!所以,就不要用这种方式来遍历索引数组了
3.类常量可见范围设定
之前类里面额常量用const
申明,是没有可见属性的。现在把方法的可见属性移植了过来:
<?php class ConstDemo { // 常量默认为 public const PUBLIC_CONST = 0; // 可以自定义常量的可见范围 public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; // 多个常量同时声明只能有一个属性 private const FOO = 1, BAR = 2; }
使用方法和类的方法一样。就不多详述了。
4.支持负的字符串偏移
有2个更新,1是字符串直接取,2是strpos函数第三个参数支持负数。表示从尾部取。
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
string变量可以直接取值,不用通过变量名,是在php5.5加入的。现在可以从尾部取:
var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r
5.多条件 catch
在以往的 try … catch 语句中,每个 catch 只能设定一个条件判断:
try { // Some code...} catch (ExceptionType1 $e) { // 处理 ExceptionType1} catch (ExceptionType2 $e) { // 处理 ExceptionType2} catch (Exception $e) { // ...}
现在可以多个一起处理。用”|
” 分割。
try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (Exception $e) { // ...}
php7.2
php 7.2大都是底层的更新,提高性能。没有太大常用语法层面的更新,这里就略过了。
之前写过php7.0以及老版本的php各大版本的跟新点以及新功能。今天看下php7.1和php7.2的新功能。
php7.1 新增功能
1.可为空(Nullable)类型
参数和返回值的类型声明可以通过在类型名称前添加一个问号(?
)来标记为空(null)。表明函数参数或者返回值的类型要么为指定类型,要么为 null。
看下例子:
function testReturn(?string $name){ return $name; } var_dump(testReturn('yangyi')); var_dump(testReturn(null)); var_dump(testReturn2());
打印输出:
$ php php71.phpstring(6) "yangyi"NULL PHP Fatal error: Uncaught ArgumentCountError: Too few arguments to function testReturn(), 0 passed in php71.php on line 22 and exactly 1 expected in php71.php:14Stack trace:#0 php71.php(22): testReturn()#1 {main} thrown in php71.php on line 14
如上如:第三个报了一个致命的错误。
再来看下,函数返回值是Nullable
的情况:
function testReturn3() : ?string{ //return "abc"; //return null;} var_dump(testReturn3());
如果加了?
要么返回 string ,要么返回null。不能啥也不返还。会报错。
2.void返回类型
PHP7.0 添加了指定函数返回类型的特性,但是返回类型却不能指定为 void,7.1 的这个特性算是一个补充。定义返回类型为 void
的函数不能有返回值,即使返回 null 也不行:
function testReturn4() : void{ //1. 要么啥都不返还 ok //2. 要么只return; ok //return; //3. return null 也会报错 //return null; //4. return 4 会报错 //return 4;}
Fatal error: A void function must not return a value in /php71.php on line 70
还有就是,void 只能用于返回值,不能用于参数中。比如下面的会报错:
function testReturn6(void $a) : void{} var_dump(testReturn6());
PHP Fatal error: void cannot be used as a parameter type in php71.php on line 73
如果在类的继承中,申明为void返回类型的方法,子类要是继承重写,也只能返回void, 否则会触发错误:
<?php class Foo{ public function bar(): void { } }class Foobar extends Foo{ // 覆盖失败 public function bar(): array { // Fatal error: Declaration of Foobar::bar() must be compatible with Foo::bar(): void } }
所以,你必须这样,就不会报错:
class Foo{ public $a; public function bar(): void { $this->a = 2; } }class Foobar extends Foo{ // 覆盖成功 public function bar(): void { $this->a = 3; } }
3.list 的方括号([]
)简写以及增加指定key
可以用list 来快速遍历得到数组里面的值。现在可以用[]
简写了。
$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}
此外,此次更新的list,针对索引数组,还可以指定 key,这个升级非常棒,非常方便。
$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}
在这个功能没有之前,我们一般会用while
+ each
的方式来用list
遍历索引数组:
$data = [ ["id" => 1, "name" => 'Tom'], ["id" => 2, "name" => 'Fred'], ];while (list($id, name) = each($data)) { echo "$key => $val\n"; }
注意:PHP 7.2 中已经将 each 函数移除了!所以,就不要用这种方式来遍历索引数组了
3.类常量可见范围设定
之前类里面额常量用const
<?php class ConstDemo { // 常量默认为 public const PUBLIC_CONST = 0; // 可以自定义常量的可见范围 public const PUBLIC_CONST_B = 2; protected const PROTECTED_CONST = 3; private const PRIVATE_CONST = 4; // 多个常量同时声明只能有一个属性 private const FOO = 1, BAR = 2; }인쇄 출력:
var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
위와 동일: 세 번째는 치명적인 오류를 보고했습니다. 함수 반환 값이 Nullable
인 경우를 살펴보겠습니다. 🎜var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r🎜
?
를 추가하면 문자열 또는 null을 반환합니다. 아무것도 반환할 수 없습니다. 오류가 보고됩니다. 🎜🎜2.void return type🎜🎜PHP7.0에는 함수 반환 유형을 지정하는 기능이 추가되었지만 반환 유형을 void로 지정할 수는 없습니다. 7.1의 이 기능은 보완 사항입니다. void
반환 유형으로 정의된 함수는 null을 반환하더라도 반환 값을 가질 수 없습니다. 🎜try { // Some code...} catch (ExceptionType1 $e) { // 处理 ExceptionType1} catch (ExceptionType2 $e) { // 处理 ExceptionType2} catch (Exception $e) { // ...}
try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (Exception $e) { // ...}🎜또한 void는 반환 값에만 사용할 수 있고 매개 변수에는 사용할 수 없습니다. 예를 들어 다음 오류가 보고됩니다. 🎜rrreeerrreee🎜클래스 상속에서 메소드가 void 반환 유형으로 선언된 경우 하위 클래스가 이를 상속하고 재정의하면 void만 반환할 수 있으며, 그렇지 않으면 오류가 발생합니다. : 🎜rrreee🎜따라서 이렇게 해야 합니다. 오류가 보고되지 않습니다. 🎜rrreee🎜3. 대괄호(
[]
)는 목록의 약어이며 지정된 키🎜🎜를 추가하는 데 사용할 수 있습니다. 목록을 빠르게 탐색하여 배열의 값을 가져옵니다. 이제 []
약어를 사용할 수 있습니다. 🎜rrreee🎜또한 이 업데이트된 목록은 인덱스 배열의 키를 지정할 수도 있습니다. 이 업그레이드는 훌륭하고 매우 편리합니다. 🎜rrreee🎜이 기능을 사용할 수 없기 전에는 일반적으로 while
+ each
를 사용하여 list
를 사용하여 인덱스 배열을 탐색했습니다. 🎜rrreee🎜참고: PHP 7.2에서는 각 함수가 제거되었습니다! 따라서 인덱스 배열을 순회하는 데 이 방법을 사용하지 마세요🎜🎜3. 클래스 상수의 표시 범위 설정🎜🎜이전에는 클래스의 상수가 const
로 선언되었으며 표시되는 속성이 없었습니다. . 이제 메소드의 눈에 보이는 속성이 이식되었습니다. 🎜rrreee🎜사용 방법은 클래스의 방법과 동일합니다. 자세한 내용은 없습니다. 🎜🎜4. 음수 문자열 오프셋 지원🎜🎜 두 가지 업데이트가 있습니다. 첫 번째는 문자열을 직접 가져오는 것이고, 두 번째는 strpos 함수의 세 번째 매개변수가 음수를 지원한다는 것입니다. 꼬리부터 취함을 나타냅니다. 🎜rrreee🎜문자열 변수는 변수 이름을 사용하지 않고 직접 값을 가져올 수 있습니다. php5.5에 추가되었습니다. 이제 꼬리에서 가져올 수 있습니다: 🎜rrreee🎜5. 다중 조건 catch🎜🎜이전 try...catch 문에서 각 catch는 하나의 조건부 판단만 설정할 수 있습니다. 🎜rrreee🎜이제 여러 조건을 함께 처리할 수 있습니다. "|
"로 분할합니다. 🎜rrreeephp7.2
🎜php 7.2는 대부분 성능 향상을 위한 하위 수준 업데이트입니다. 공통 구문 수준에는 업데이트가 많지 않으므로 여기서는 건너뛰겠습니다. 🎜🎜저는 이전에 php7.0과 이전 버전의 php의 새로운 기능과 새로운 기능에 대해 글을 쓴 적이 있습니다. 오늘은 php7.1과 php7.2의 새로운 기능을 살펴보겠습니다. 🎜php7.1의 새로운 기능
🎜1. Nullable 유형🎜🎜 매개변수 및 반환 값에 대한 유형 선언은 유형 앞에 물음표(?
)를 추가하여 만들 수 있습니다. name >)을 사용하여 null로 표시합니다. 함수 매개변수 또는 반환 값의 유형이 지정된 유형이거나 null임을 나타냅니다. 🎜🎜예를 보세요: 🎜rrreee🎜인쇄 출력: 🎜rrreee🎜위와 동일: 세 번째는 치명적인 오류를 보고했습니다. 🎜🎜함수 반환 값이 Nullable
인 경우를 살펴보겠습니다. 🎜rrreee🎜 ?
를 추가하면 문자열 또는 null을 반환합니다. 아무것도 반환할 수 없습니다. 오류가 보고됩니다. 🎜🎜2.void return type🎜🎜PHP7.0에는 함수 반환 유형을 지정하는 기능이 추가되었지만 반환 유형을 void로 지정할 수는 없습니다. 7.1의 이 기능은 보완 사항입니다. void
반환 유형으로 정의된 함수는 null을 반환하더라도 반환 값을 가질 수 없습니다. 🎜rrreeerrreee🎜또한 void는 반환 값에만 사용할 수 있고 매개 변수에는 사용할 수 없습니다. 예를 들어 다음 오류가 보고됩니다. 🎜rrreeerrreee🎜클래스 상속에서 메소드가 void 반환 유형으로 선언된 경우 하위 클래스가 이를 상속하고 재정의하면 void만 반환할 수 있으며, 그렇지 않으면 오류가 발생합니다. : 🎜rrreee🎜따라서 이렇게 해야 합니다. 오류가 보고되지 않습니다. 🎜rrreee🎜3. 대괄호([]
)는 목록의 약어이며 지정된 키🎜🎜를 추가하는 데 사용할 수 있습니다. 목록을 빠르게 탐색하여 배열의 값을 가져옵니다. 이제 []
약어를 사용할 수 있습니다. 🎜rrreee🎜또한 이 업데이트된 목록은 인덱스 배열의 키를 지정할 수도 있습니다. 이 업그레이드는 훌륭하고 매우 편리합니다. 🎜rrreee🎜이 기능을 사용할 수 없기 전에는 일반적으로 while
+ each
를 사용하여 list
를 사용하여 인덱스 배열을 탐색했습니다. 🎜rrreee🎜참고: PHP 7.2에서는 각 함수가 제거되었습니다! 따라서 인덱스 배열을 순회하는 데 이 방법을 사용하지 마세요🎜🎜3. 클래스 상수의 표시 범위 설정🎜🎜이전에는 클래스의 상수가 const
로 선언되었으며 표시되는 속성이 없었습니다. . 이제 메소드의 눈에 보이는 속성이 이식되었습니다. 🎜rrreee🎜사용 방법은 클래스의 방법과 동일합니다. 자세한 내용은 다루지 않겠습니다. 🎜🎜4. 음수 문자열 오프셋 지원🎜🎜 두 가지 업데이트가 있습니다. 첫 번째는 문자열을 직접 가져오는 것이고, 두 번째는 strpos 함수의 세 번째 매개변수가 음수를 지원한다는 것입니다. 꼬리부터 취함을 나타냅니다. 🎜var_dump("abcdef"[-2]); // evar_dump(strpos("aabbcc", "b", -3)); //3
string变量可以直接取值,不用通过变量名,是在php5.5加入的。现在可以从尾部取:
var_dump("abcdef"[-2]); // 从末尾取倒数第2个字符:evar_dump("abcdef"[2]); // 从前面取第2个,从0开始:c$string = 'bar';echo $string[1], $string[-1]; // a r
5.多条件 catch
在以往的 try … catch 语句中,每个 catch 只能设定一个条件判断:
try { // Some code...} catch (ExceptionType1 $e) { // 处理 ExceptionType1} catch (ExceptionType2 $e) { // 处理 ExceptionType2} catch (Exception $e) { // ...}
现在可以多个一起处理。用”|
” 分割。
try { // Some code... } catch (ExceptionType1 | ExceptionType2 $e) { // 对于 ExceptionType1 和 ExceptionType2 的处理 } catch (Exception $e) { // ...}
php7.2
php 7.2大都是底层的更新,提高性能。没有太大常用语法层面的更新,这里就略过了。
相关推荐:
위 내용은 PHP7.1 및 7.2의 새로운 기능에 대한 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

세션 고정 공격을 방지하는 효과적인 방법은 다음과 같습니다. 1. 사용자 로그인 한 후 세션 ID 재생; 2. 보안 세션 ID 생성 알고리즘을 사용하십시오. 3. 세션 시간 초과 메커니즘을 구현하십시오. 4. HTTPS를 사용한 세션 데이터를 암호화합니다. 이러한 조치는 세션 고정 공격에 직면 할 때 응용 프로그램이 파괴 할 수 없도록 할 수 있습니다.

서버 측 세션 스토리지가없는 토큰에 저장되는 토큰 기반 인증 시스템 인 JSONWEBTOKENS (JWT)를 사용하여 세션없는 인증 구현을 수행 할 수 있습니다. 1) JWT를 사용하여 토큰을 생성하고 검증하십시오. 2) HTTPS가 토큰이 가로 채지 못하도록하는 데 사용되도록, 3) 클라이언트 측의 토큰을 안전하게 저장, 4) 변조 방지를 방지하기 위해 서버 측의 토큰을 확인하기 위해 단기 접근 메커니즘 및 장기 상쾌한 토큰을 구현하십시오.

PHP 세션의 보안 위험에는 주로 세션 납치, 세션 고정, 세션 예측 및 세션 중독이 포함됩니다. 1. HTTPS를 사용하고 쿠키를 보호하여 세션 납치를 방지 할 수 있습니다. 2. 사용자가 로그인하기 전에 세션 ID를 재생하여 세션 고정을 피할 수 있습니다. 3. 세션 예측은 세션 ID의 무작위성과 예측 불가능 성을 보장해야합니다. 4. 세션 중독 데이터를 확인하고 필터링하여 세션 중독을 방지 할 수 있습니다.

PHP 세션을 파괴하려면 먼저 세션을 시작한 다음 데이터를 지우고 세션 파일을 파괴해야합니다. 1. 세션을 시작하려면 세션 _start ()를 사용하십시오. 2. Session_Unset ()을 사용하여 세션 데이터를 지우십시오. 3. 마지막으로 Session_Destroy ()를 사용하여 세션 파일을 파괴하여 데이터 보안 및 리소스 릴리스를 보장하십시오.

PHP의 기본 세션 저장 경로를 변경하는 방법은 무엇입니까? 다음 단계를 통해 달성 할 수 있습니다. session_save_path를 사용하십시오 ( '/var/www/sessions'); session_start (); PHP 스크립트에서 세션 저장 경로를 설정합니다. php.ini 파일에서 세션을 설정하여 세션 저장 경로를 전 세계적으로 변경하려면 세션을 설정하십시오. memcached 또는 redis를 사용하여 ini_set ( 'session.save_handler', 'memcached')과 같은 세션 데이터를 저장합니다. ini_set (

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
