PHP 7 - คู่มือฉบับย่อ
PHP 7 คืออะไร?
PHP 7 เป็นภาษาโปรแกรม PHP รุ่นสำคัญและได้รับการขนานนามว่าเป็นการปฏิวัติวิธีการพัฒนาและส่งมอบเว็บแอปพลิเคชันสำหรับมือถือไปยังองค์กรและระบบคลาวด์ รุ่นนี้ถือเป็นการเปลี่ยนแปลงที่สำคัญที่สุดสำหรับ PHP หลังจากการเปิดตัว PHP 5 ในปี 2547
คุณสมบัติใหม่
มีฟีเจอร์มากมายที่เพิ่มเข้ามาใน PHP 7 ซึ่งคุณสมบัติที่สำคัญที่สุดจะกล่าวถึงด้านล่าง -
Improved performance - การรวมโค้ด PHPNG ใน PHP7 จะเร็วกว่า PHP 5 ถึงสองเท่า
Lower Memory Consumption - PHP 7 ที่ปรับให้เหมาะสมใช้ทรัพยากรน้อยลง
Scalar type declarations - ตอนนี้สามารถบังคับใช้พารามิเตอร์และประเภทผลตอบแทนได้
Consistent 64-bit support - การสนับสนุนที่สอดคล้องกันสำหรับเครื่องสถาปัตยกรรม 64 บิต
Improved Exception hierarchy - ปรับปรุงลำดับชั้นของข้อยกเว้น
Many fatal errors converted to Exceptions - ช่วงของข้อยกเว้นเพิ่มขึ้นครอบคลุมข้อผิดพลาดร้ายแรงจำนวนมากที่ถูกแปลงเป็นข้อยกเว้น
Secure random number generator - การเพิ่ม API ตัวสร้างตัวเลขสุ่มที่ปลอดภัยใหม่
Deprecated SAPIs and extensions removed - SAPI และส่วนขยายที่เก่าและไม่รองรับต่างๆจะถูกลบออกจากเวอร์ชันล่าสุด
The null coalescing operator (??) - เพิ่มตัวดำเนินการประสาน null ใหม่
Return and Scalar Type Declarations - รองรับประเภทการส่งคืนและประเภทพารามิเตอร์ที่เพิ่ม
Anonymous Classes - รองรับการเพิ่มแบบไม่ระบุชื่อ
Zero cost asserts - รองรับการยืนยันค่าใช้จ่ายเป็นศูนย์เพิ่ม
PHP 7 ใช้ Zend Engine 3.0 ใหม่เพื่อปรับปรุงประสิทธิภาพของแอปพลิเคชันเกือบสองเท่าและใช้หน่วยความจำได้ดีขึ้น 50% เมื่อเทียบกับ PHP 5.6 ช่วยให้สามารถให้บริการผู้ใช้พร้อมกันได้มากขึ้นโดยไม่ต้องใช้ฮาร์ดแวร์เพิ่มเติม PHP 7 ได้รับการออกแบบและปรับโครงสร้างใหม่โดยพิจารณาจากปริมาณงานในปัจจุบัน
ตามทีมZendภาพประกอบต่อไปนี้แสดงการเปรียบเทียบประสิทธิภาพของ PHP 7 กับ PHP 5.6 และ HHVM 3.7 บนแอปพลิเคชันที่ใช้ PHP ยอดนิยม
Magento 1.9
PHP 7 พิสูจน์ตัวเองได้เร็วขึ้นกว่าสองเท่าเมื่อเทียบกับ PHP 5.6 ในขณะที่ทำธุรกรรม Magento
Drupal 7
PHP 7 พิสูจน์ตัวเองได้เร็วขึ้นกว่าสองเท่าเมื่อเทียบกับ PHP 5.6 ในขณะที่ดำเนินการธุรกรรม Drupal
Wordpress 3.6
PHP 7 พิสูจน์ตัวเองได้เร็วกว่าสองเท่าเมื่อเทียบกับ PHP 5.6 ในขณะที่ดำเนินการธุรกรรม Wordpress
การเปรียบเทียบภาษาไดนามิก
ลองใช้ตัวเลือกออนไลน์
เราได้ตั้งค่าสภาพแวดล้อมการเขียนโปรแกรม PHP ออนไลน์เพื่อให้คุณสามารถรวบรวมและดำเนินการตัวอย่างทั้งหมดที่มีอยู่ทางออนไลน์ ช่วยให้คุณมั่นใจในสิ่งที่คุณกำลังอ่านและช่วยให้คุณสามารถตรวจสอบโปรแกรมด้วยตัวเลือกต่างๆ อย่าลังเลที่จะแก้ไขตัวอย่างใด ๆ และดำเนินการทางออนไลน์
ลองใช้ตัวอย่างต่อไปนี้โดยใช้คอมไพเลอร์ออนไลน์ของเราที่CodingGround
<html> <head> <title>Online PHP Script Execution</title> </head> <body> <?php echo "<h1>Hello, PHP!</h1>"; ?> </body> </html>
สำหรับตัวอย่างส่วนใหญ่ที่ให้ไว้ในบทช่วยสอนนี้คุณจะพบไฟล์ Try itตัวเลือกในส่วนรหัสเว็บไซต์ของเราที่มุมขวาบนซึ่งจะนำคุณไปยังคอมไพเลอร์ออนไลน์ ดังนั้นเพียงแค่ใช้และสนุกกับการเรียนรู้ของคุณ
ในการพัฒนาและเรียกใช้เว็บเพจ PHP จำเป็นต้องติดตั้งองค์ประกอบสำคัญสามอย่างในระบบคอมพิวเตอร์ของคุณ
Web Server- PHP ทำงานร่วมกับซอฟต์แวร์ Web Server เกือบทั้งหมดรวมถึง Internet Information Server (IIS) ของ Microsoft แต่ส่วนใหญ่ที่ใช้คือ Apache Server ดาวน์โหลด Apache ได้ฟรีที่นี่ -http://httpd.apache.org/download.cgi
Database- PHP PHP ทำงานร่วมกับซอฟต์แวร์ฐานข้อมูลเกือบทั้งหมดรวมถึง Oracle และ Sybase แต่ที่ใช้กันมากที่สุดคือฐานข้อมูล MySQL ดาวน์โหลด MySQL ได้ฟรีที่นี่ -http://www.mysql.com/downloads/
PHP Parser- ในการประมวลผลคำสั่งสคริปต์ PHP ต้องติดตั้งตัวแยกวิเคราะห์เพื่อสร้างเอาต์พุต HTML ที่สามารถส่งไปยังเว็บเบราว์เซอร์ได้ บทช่วยสอนนี้จะแนะนำวิธีการติดตั้ง PHP parser บนคอมพิวเตอร์ของคุณ
การติดตั้ง PHP Parser
ก่อนดำเนินการต่อสิ่งสำคัญคือต้องตรวจสอบให้แน่ใจว่าคุณได้ตั้งค่าสภาพแวดล้อมที่เหมาะสมบนเครื่องของคุณเพื่อพัฒนาโปรแกรมเว็บโดยใช้ PHP เก็บไฟล์ php ต่อไปนี้ไว้ในโฟลเดอร์ htdocs ของ Apache
phpinfo.php
<?php
phpinfo();
?>
พิมพ์ที่อยู่ต่อไปนี้ลงในช่องที่อยู่ของเบราว์เซอร์
http://127.0.0.1/phpinfo.php
หากหน้านี้แสดงข้อมูลที่เกี่ยวข้องกับการติดตั้ง PHP ของคุณแสดงว่าคุณได้ติดตั้ง PHP และ Webserver อย่างถูกต้อง มิฉะนั้นคุณต้องทำตามขั้นตอนที่กำหนดเพื่อติดตั้ง PHP บนคอมพิวเตอร์ของคุณ
ส่วนนี้จะแนะนำให้คุณติดตั้งและกำหนดค่า PHP บนสี่แพลตฟอร์มต่อไปนี้ -
การติดตั้ง PHP บน Linux หรือ Unix ด้วย Apache
การติดตั้ง PHP บน Mac OS X ด้วย Apache
การติดตั้ง PHP บน Windows NT / 2000 / XP พร้อม IIS
การติดตั้ง PHP บน Windows NT / 2000 / XP ด้วย Apache
การกำหนดค่า Apache
หากคุณใช้ Apache เป็นเว็บเซิร์ฟเวอร์ส่วนนี้จะแนะนำให้คุณแก้ไข Apache Configuration Files
ตรวจสอบที่นี่ - การกำหนดค่า PHP ในเซิร์ฟเวอร์ Apache
การกำหนดค่าไฟล์ PHP.INI
ไฟล์กำหนดค่า PHP php.iniเป็นวิธีสุดท้ายและทันทีที่จะส่งผลต่อการทำงานของ PHP
ตรวจสอบที่นี่ - การกำหนดค่าไฟล์ PHP.INI
การกำหนดค่า Windows IIS
ในการกำหนดค่า IIS บนเครื่อง Windows ของคุณคุณสามารถอ้างอิงคู่มืออ้างอิง IIS ของคุณที่จัดส่งมาพร้อมกับ IIS
ใน PHP 7 ได้มีการเปิดตัวคุณลักษณะใหม่การประกาศประเภท Scalar การประกาศประเภทสเกลาร์มีสองตัวเลือก -
coercive - การบีบบังคับเป็นโหมดเริ่มต้นและไม่จำเป็นต้องระบุ
strict - โหมดเข้มงวดต้องบอกใบ้อย่างชัดเจน
ประเภทต่อไปนี้สำหรับพารามิเตอร์ฟังก์ชันสามารถบังคับใช้ได้โดยใช้โหมดด้านบน -
- int
- float
- bool
- string
- interfaces
- array
- callable
ตัวอย่าง - โหมดบีบบังคับ
<?php
// Coercive mode
function sum(int ...$ints) {
return array_sum($ints);
}
print(sum(2, '3', 4.1));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
9
ตัวอย่าง - โหมดเข้มงวด
<?php
// Strict mode
declare(strict_types=1);
function sum(int ...$ints) {
return array_sum($ints);
}
print(sum(2, '3', 4.1));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Fatal error: Uncaught TypeError: Argument 2 passed to sum() must be of the type integer, string given, ...
ใน PHP 7 คุณสมบัติใหม่ Return type declarationsได้รับการแนะนำ การประกาศประเภทการส่งคืนระบุชนิดของค่าที่ฟังก์ชันควรส่งคืน สามารถประกาศประเภทผลตอบแทนต่อไปนี้ได้
- int
- float
- bool
- string
- interfaces
- array
- callable
ตัวอย่าง - ประเภทการส่งคืนที่ถูกต้อง
<?php
declare(strict_types = 1);
function returnIntValue(int $value): int {
return $value;
}
print(returnIntValue(5));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
5
ตัวอย่าง - ประเภทการส่งคืนไม่ถูกต้อง
<?php
declare(strict_types = 1);
function returnIntValue(int $value): int {
return $value + 1.0;
}
print(returnIntValue(5));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Fatal error: Uncaught TypeError: Return value of returnIntValue() must be of the type integer, float returned...
ใน PHP 7 คุณสมบัติใหม่ null coalescing operator (??)ได้รับการแนะนำ ใช้เพื่อแทนที่ไฟล์ternaryการทำงานร่วมกับฟังก์ชัน isset () Nullตัวดำเนินการรวมกันจะส่งคืนตัวถูกดำเนินการตัวแรกหากมีอยู่และไม่ใช่โมฆะ มิฉะนั้นจะส่งกลับตัวถูกดำเนินการที่สอง
ตัวอย่าง
<?php
// fetch the value of $_GET['user'] and returns 'not passed'
// if username is not passed
$username = $_GET['username'] ?? 'not passed';
print($username);
print("<br/>");
// Equivalent code using ternary operator
$username = isset($_GET['username']) ? $_GET['username'] : 'not passed';
print($username);
print("<br/>");
// Chaining ?? operation
$username = $_GET['username'] ?? $_POST['username'] ?? 'not passed';
print($username);
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
not passed
not passed
not passed
ใน PHP 7 ได้มีการเปิดตัวคุณลักษณะใหม่ผู้ให้บริการยานอวกาศ ใช้เพื่อเปรียบเทียบสองนิพจน์ ส่งกลับค่า -1, 0 หรือ 1 เมื่อนิพจน์แรกมีค่าน้อยกว่าเท่ากับหรือมากกว่านิพจน์ที่สองตามลำดับ
ตัวอย่าง
<?php
//integer comparison
print( 1 <=> 1);print("<br/>");
print( 1 <=> 2);print("<br/>");
print( 2 <=> 1);print("<br/>");
print("<br/>");
//float comparison
print( 1.5 <=> 1.5);print("<br/>");
print( 1.5 <=> 2.5);print("<br/>");
print( 2.5 <=> 1.5);print("<br/>");
print("<br/>");
//string comparison
print( "a" <=> "a");print("<br/>");
print( "a" <=> "b");print("<br/>");
print( "b" <=> "a");print("<br/>");
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
0
-1
1
0
-1
1
0
-1
1
ตอนนี้สามารถกำหนดค่าคงที่อาร์เรย์ได้โดยใช้ define()ฟังก์ชัน ใน PHP 5.6 สามารถกำหนดได้โดยใช้ไฟล์const คำสำคัญ.
ตัวอย่าง
<?php
//define a array using define function
define('animals', [
'dog',
'cat',
'bird'
]);
print(animals[1]);
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
cat
ขณะนี้สามารถกำหนดคลาสที่ไม่ระบุชื่อได้โดยใช้คลาสใหม่ คลาส Anonymous สามารถใช้แทนนิยามคลาสแบบเต็มได้
ตัวอย่าง
<?php
interface Logger {
public function log(string $msg);
}
class Application {
private $logger;
public function getLogger(): Logger {
return $this->logger;
}
public function setLogger(Logger $logger) {
$this->logger = $logger;
}
}
$app = new Application;
$app->setLogger(new class implements Logger {
public function log(string $msg) {
print($msg);
}
});
$app->getLogger()->log("My first Log Message");
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
My first Log Message
Closure::call()วิธีการถูกเพิ่มเป็นวิธีชวเลขเพื่อผูกขอบเขตวัตถุกับการปิดชั่วคราวและเรียกใช้ ประสิทธิภาพเร็วกว่ามากเมื่อเทียบกับbindTo ของ PHP 5.6
ตัวอย่าง - ก่อน PHP 7
<?php
class A {
private $x = 1;
}
// Define a closure Pre PHP 7 code
$getValue = function() {
return $this->x;
};
// Bind a clousure
$value = $getValue->bindTo(new A, 'A');
print($value());
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
1
ตัวอย่าง - PHP 7+
<?php
class A {
private $x = 1;
}
// PHP 7+ code, Define
$value = function() {
return $this->x;
};
print($value->call(new A));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
1
PHP 7 แนะนำตัวกรอง unserialize()ฟังก์ชันเพื่อให้มีความปลอดภัยที่ดีขึ้นเมื่อยกเลิกการกำหนดค่าอ็อบเจ็กต์บนข้อมูลที่ไม่น่าเชื่อถือ ป้องกันการแทรกโค้ดที่เป็นไปได้และช่วยให้นักพัฒนาสามารถกำหนดคลาสที่อนุญาตพิเศษซึ่งสามารถไม่ได้รับอนุญาตได้
ตัวอย่าง
<?php
class MyClass1 {
public $obj1prop;
}
class MyClass2 {
public $obj2prop;
}
$obj1 = new MyClass1();
$obj1->obj1prop = 1;
$obj2 = new MyClass2();
$obj2->obj2prop = 2;
$serializedObj1 = serialize($obj1);
$serializedObj2 = serialize($obj2);
// default behaviour that accepts all classes
// second argument can be ommited.
// if allowed_classes is passed as false, unserialize converts all objects into __PHP_Incomplete_Class object
$data = unserialize($serializedObj1 , ["allowed_classes" => true]);
// converts all objects into __PHP_Incomplete_Class object except those of MyClass1 and MyClass2
$data2 = unserialize($serializedObj2 , ["allowed_classes" => ["MyClass1", "MyClass2"]]);
print($data->obj1prop);
print("<br/>");
print($data2->obj2prop);
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
1
2
ใน PHP7 ไฟล์ IntlCharมีการเพิ่มคลาสซึ่งพยายามที่จะเปิดเผยฟังก์ชันการทำงานของ ICU เพิ่มเติม คลาสนี้กำหนดวิธีการคงที่และค่าคงที่จำนวนหนึ่งซึ่งสามารถใช้เพื่อจัดการกับอักขระยูนิโคด คุณจำเป็นต้องมีIntl ติดตั้งส่วนขยายก่อนที่จะใช้คลาสนี้
ตัวอย่าง
<?php
printf('%x', IntlChar::CODEPOINT_MAX);
print (IntlChar::charName('@'));
print(IntlChar::ispunct('!'));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
10ffff
COMMERCIAL AT
true
ใน PHP 7 มีการนำเสนอฟังก์ชันใหม่สองฟังก์ชันต่อไปนี้เพื่อสร้างจำนวนเต็มและสตริงที่ปลอดภัยในการเข้ารหัสด้วยวิธีข้ามแพลตฟอร์ม
random_bytes() - สร้างไบต์สุ่มหลอกที่ปลอดภัยด้วยการเข้ารหัส
random_int() - สร้างจำนวนเต็มสุ่มหลอกที่ปลอดภัยด้วยการเข้ารหัส
random_bytes ()
random_bytes () สร้างสตริงของไบต์สุ่มการเข้ารหัสที่มีความยาวตามอำเภอใจซึ่งเหมาะสำหรับการใช้งานในการเข้ารหัสเช่นเมื่อสร้างเกลือคีย์หรือเวกเตอร์การเริ่มต้น
ไวยากรณ์
string random_bytes ( int $length )
พารามิเตอร์
length - ความยาวของสตริงสุ่มที่ควรส่งคืนเป็นไบต์
ส่งคืนค่า
ส่งคืนสตริงที่มีจำนวนไบต์สุ่มที่ปลอดภัยที่เข้ารหัสลับที่ร้องขอ
ข้อผิดพลาด / ข้อยกเว้น
หากไม่พบแหล่งที่มาของการสุ่มที่เหมาะสมข้อยกเว้นจะถูกโยนทิ้ง
หากกำหนดพารามิเตอร์ที่ไม่ถูกต้อง a TypeError จะถูกโยนทิ้ง
หากระบุความยาวของไบต์ที่ไม่ถูกต้องข้อผิดพลาดจะถูกโยนทิ้ง
ตัวอย่าง
<?php
$bytes = random_bytes(5);
print(bin2hex($bytes));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
54cc305593
random_int ()
random_int() สร้างจำนวนเต็มสุ่มการเข้ารหัสที่เหมาะสำหรับใช้ในกรณีที่ผลลัพธ์ที่เป็นกลางมีความสำคัญ
ไวยากรณ์
int random_int ( int $min , int $max )
พารามิเตอร์
min - ค่าต่ำสุดที่จะส่งคืนซึ่งต้องเป็น PHP_INT_MIN หรือสูงกว่า.
max - ค่าสูงสุดที่จะส่งคืนซึ่งต้องน้อยกว่าหรือเท่ากับ PHP_INT_MAX.
ส่งคืนค่า
ส่งคืนจำนวนเต็มสุ่มที่ปลอดภัยในการเข้ารหัสในช่วงต่ำสุดถึงสูงสุดรวม
ข้อผิดพลาด / ข้อยกเว้น
หากไม่พบแหล่งที่มาของการสุ่มที่เหมาะสมไฟล์ Exception จะถูกโยนทิ้ง
หากกำหนดพารามิเตอร์ที่ไม่ถูกต้อง a TypeError จะถูกโยนทิ้ง
หากค่าสูงสุดน้อยกว่านาทีเครื่องหมาย Error จะถูกโยนทิ้ง
ตัวอย่าง
<?php
print(random_int(100, 999));
print(" ");
print(random_int(-1000, 0));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
614
-882
Expectationsเป็นการเพิ่มประสิทธิภาพที่เข้ากันได้กับฟังก์ชัน assert () รุ่นเก่า ความคาดหวังช่วยให้การยืนยันรหัสการผลิตเป็นศูนย์และให้ความสามารถในการโยนข้อยกเว้นที่กำหนดเองเมื่อการยืนยันล้มเหลว assert () เป็นโครงสร้างภาษาโดยที่พารามิเตอร์แรกเป็นนิพจน์เมื่อเทียบกับการเป็นสตริงหรือบูลีนที่จะทดสอบ
คำสั่งการกำหนดค่าสำหรับการยืนยัน ()
คำสั่ง | ค่าเริ่มต้น | ค่าที่เป็นไปได้ |
---|---|---|
zend.assertions | 1 | 1 - สร้างและรันโค้ด (โหมดการพัฒนา) 0 - สร้างรหัส แต่ข้ามไปรอบ ๆ ที่รันไทม์ -1 - ไม่สร้างรหัส (โหมดการผลิต) |
assert.exception | 0 | 1 - โยนเมื่อการยืนยันล้มเหลวไม่ว่าจะโดยการโยนวัตถุที่จัดให้เป็นข้อยกเว้นหรือโดยการขว้างปาใหม่ AssertionError วัตถุหากไม่ได้ระบุข้อยกเว้น 0 - ใช้หรือสร้าง Throwable ตามที่อธิบายไว้ข้างต้น แต่จะสร้างคำเตือนขึ้นอยู่กับวัตถุนั้นแทนที่จะโยนทิ้ง (เข้ากันได้กับพฤติกรรม PHP 5) |
พารามิเตอร์
assertion- การยืนยัน ใน PHP 5 สิ่งนี้ต้องเป็นสตริงที่จะประเมินหรือบูลีนที่จะทดสอบ ใน PHP 7 นี่อาจเป็นนิพจน์ใด ๆ ที่ส่งคืนค่าซึ่งจะถูกดำเนินการและผลลัพธ์จะถูกใช้เพื่อระบุว่าการยืนยันสำเร็จหรือล้มเหลว
description - คำอธิบายเพิ่มเติมที่จะรวมอยู่ในข้อความแสดงความล้มเหลวหากการยืนยันล้มเหลว
exception - ใน PHP 7 พารามิเตอร์ที่สองสามารถเป็นไฟล์ Throwable วัตถุแทนสตริงอธิบายซึ่งในกรณีนี้เป็นวัตถุที่จะถูกโยนถ้าการยืนยันล้มเหลวและ assert.exception เปิดใช้งานคำสั่งการกำหนดค่า
ส่งคืนค่า
FALSE หากการยืนยันเป็นเท็จ TRUE มิฉะนั้น.
ตัวอย่าง
<?php
ini_set('assert.exception', 1);
class CustomError extends AssertionError {}
assert(false, new CustomError('Custom Error Message!'));
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Fatal error: Uncaught CustomError: Custom Error Message! in...
ตั้งแต่ PHP7 เป็นต้นไปสามารถใช้คำสั่ง single use เพื่ออิมพอร์ตคลาสฟังก์ชันและค่าคงที่จากเนมสเปซเดียวกันแทนการใช้คำสั่งหลาย ๆ
ตัวอย่าง
<?php
// Before PHP 7
use com\tutorialspoint\ClassA;
use com\tutorialspoint\ClassB;
use com\tutorialspoint\ClassC as C;
use function com\tutorialspoint\fn_a;
use function com\tutorialspoint\fn_b;
use function com\tutorialspoint\fn_c;
use const com\tutorialspoint\ConstA;
use const com\tutorialspoint\ConstB;
use const com\tutorialspoint\ConstC;
// PHP 7+ code
use com\tutorialspoint\{ClassA, ClassB, ClassC as C};
use function com\tutorialspoint\{fn_a, fn_b, fn_c};
use const com\tutorialspoint\{ConstA, ConstB, ConstC};
?>
จาก PHP 7 การจัดการและการรายงานข้อผิดพลาดได้รับการเปลี่ยนแปลง แทนที่จะรายงานข้อผิดพลาดผ่านกลไกการรายงานข้อผิดพลาดแบบเดิมที่ใช้โดย PHP 5 ตอนนี้ข้อผิดพลาดส่วนใหญ่ได้รับการจัดการโดยการโยนข้อยกเว้นข้อผิดพลาด เช่นเดียวกับข้อยกเว้นข้อยกเว้นข้อผิดพลาดเหล่านี้จะปรากฏขึ้นจนกว่าจะถึงบล็อกจับคู่แรก หากไม่มีบล็อกที่ตรงกันแสดงว่ามีการติดตั้งตัวจัดการข้อยกเว้นเริ่มต้นด้วยset_exception_handler()จะถูกเรียก ในกรณีที่ไม่มีตัวจัดการข้อยกเว้นเริ่มต้นข้อยกเว้นจะถูกแปลงเป็นข้อผิดพลาดร้ายแรงและจะถูกจัดการเหมือนข้อผิดพลาดทั่วไป
เนื่องจากลำดับชั้นของข้อผิดพลาดไม่ได้ขยายออกจากข้อยกเว้นโค้ดที่ใช้บล็อก catch (Exception $ e) {... } เพื่อจัดการข้อยกเว้นที่ไม่ถูกตรวจจับใน PHP 5 จะไม่จัดการกับข้อผิดพลาดดังกล่าว การจับ (ข้อผิดพลาด $ e) {... } บล็อกหรือกset_exception_handler() ต้องใช้ตัวจัดการเพื่อจัดการกับข้อผิดพลาดร้ายแรง
ตัวอย่าง
<?php
class MathOperations {
protected $n = 10;
// Try to get the Division by Zero error object and display as Exception
public function doOperation(): string {
try {
$value = $this->n % 0;
return $value;
} catch (DivisionByZeroError $e) {
return $e->getMessage();
}
}
}
$mathOperationsObj = new MathOperations();
print($mathOperationsObj->doOperation());
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Modulo by zero
PHP 7 ขอแนะนำฟังก์ชันใหม่ intdiv()ซึ่งดำเนินการหารจำนวนเต็มของตัวถูกดำเนินการและส่งกลับการหารเป็น int
ตัวอย่าง
<?php
$value = intdiv(10,3);
var_dump($value);
print(" ");
print($value);
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
int(3)
3
จาก PHP7 + session_start() ฟังก์ชันยอมรับอาร์เรย์ของตัวเลือกเพื่อลบล้างคำสั่งการกำหนดคอนฟิกเซสชันที่ตั้งค่าไว้ php.ini. ตัวเลือกเหล่านี้รองรับsession.lazy_writeซึ่งเป็นค่าเริ่มต้นและทำให้ PHP เขียนทับไฟล์เซสชันใด ๆ หากข้อมูลเซสชันมีการเปลี่ยนแปลง
ตัวเลือกอื่นที่เพิ่มเข้ามาคือ read_and_closeซึ่งบ่งชี้ว่าควรอ่านข้อมูลเซสชันจากนั้นควรปิดเซสชันทันทีโดยไม่มีการเปลี่ยนแปลง ตัวอย่างเช่น Setsession.cache_limiter เป็นส่วนตัวและตั้งค่าสถานะเพื่อปิดเซสชันทันทีหลังจากอ่านเสร็จโดยใช้ข้อมูลโค้ดต่อไปนี้
<?php
session_start([
'cache_limiter' => 'private',
'read_and_close' => true,
]);
?>
ฟีเจอร์ต่อไปนี้เลิกใช้แล้วและอาจถูกลบออกจาก PHP รุ่นต่อ ๆ ไป
ตัวสร้างสไตล์ PHP 4
PHP 4 style Constructor เป็นเมธอดที่มีชื่อเดียวกับคลาสที่กำหนดไว้ตอนนี้เลิกใช้แล้วและจะถูกลบออกในอนาคต PHP 7 จะปล่อย E_DEPRECATED หากตัวสร้าง PHP 4 เป็นตัวสร้างเดียวที่กำหนดไว้ภายในคลาส ชั้นเรียนที่ใช้เมธอด __construct () จะไม่ได้รับผลกระทบ
ตัวอย่าง
<?php
class A {
function A() {
print('Style Constructor');
}
}
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Deprecated: Methods with the same name as their class will not be constructors
in a future version of PHP; A has a deprecated constructor in...
การเรียกแบบคงที่ไปยังวิธีการแบบไม่คงที่
การเรียกแบบคงที่ไปยังวิธีการแบบไม่คงที่ถูกเลิกใช้งานและอาจถูกลบออกในอนาคต
ตัวอย่าง
<?php
class A {
function b() {
print('Non-static call');
}
}
A::b();
?>
สร้างผลลัพธ์ของเบราว์เซอร์ต่อไปนี้ -
Deprecated: Non-static method A::b() should not be called statically in...
Non-static call
password_hash () ตัวเลือกเกลือ
ตัวเลือกเกลือสำหรับ password_hash()เลิกใช้งานฟังก์ชันแล้วเพื่อให้นักพัฒนาไม่สร้างเกลือของตนเอง (โดยปกติจะไม่ปลอดภัย) ฟังก์ชั่นนี้สร้างเกลือที่มีความปลอดภัยในการเข้ารหัสเมื่อผู้พัฒนาไม่ได้จัดหาเกลือให้ - ดังนั้นการสร้างเกลือแบบกำหนดเองจึงไม่จำเป็นต้องใช้อีกต่อไป
ตัวเลือกบริบท capture_session_meta SSL
capture_session_metaตัวเลือกบริบท SSL เลิกใช้งานแล้ว ขณะนี้ข้อมูลเมตา SSL ถูกใช้ผ่านไฟล์stream_get_meta_data() ฟังก์ชัน
ส่วนขยายต่อไปนี้ถูกลบออกตั้งแต่ PHP 7 เป็นต้นไป -
- ereg
- mssql
- mysql
- sybase_ct
SAPI ต่อไปนี้ถูกลบออกจาก PHP 7 เป็นต้นไป -
- aolserver
- apache
- apache_hooks
- apache2filter
- caudium
- continuity
- isapi
- milter
- nsapi
- phttpd
- pi3web
- roxen
- thttpd
- tux
- webjames