PHP 7 - Panduan Cepat
Apa itu PHP 7?
PHP 7 adalah rilis utama bahasa pemrograman PHP dan disebut-sebut sebagai revolusi dalam cara aplikasi web dapat dikembangkan dan dikirimkan untuk seluler ke perusahaan dan cloud. Rilis ini dianggap sebagai perubahan terpenting untuk PHP setelah rilis PHP 5 pada tahun 2004.
Fitur baru
Ada lusinan fitur yang ditambahkan ke PHP 7, yang paling signifikan disebutkan di bawah -
Improved performance - Setelah kode PHPNG digabungkan dalam PHP7, ini dua kali lebih cepat dari PHP 5.
Lower Memory Consumption - PHP 7 yang dioptimalkan menggunakan sumber daya yang lebih sedikit.
Scalar type declarations - Sekarang parameter dan tipe kembalian dapat diterapkan.
Consistent 64-bit support - Dukungan yang konsisten untuk mesin arsitektur 64-bit.
Improved Exception hierarchy - Hierarki pengecualian ditingkatkan.
Many fatal errors converted to Exceptions - Rentang pengecualian ditingkatkan yang mencakup banyak kesalahan fatal yang diubah sebagai pengecualian.
Secure random number generator - Penambahan API generator nomor acak aman baru.
Deprecated SAPIs and extensions removed - Berbagai SAPI dan ekstensi lama dan yang tidak didukung dihapus dari versi terbaru.
The null coalescing operator (??) - Operator penggabungan null baru ditambahkan.
Return and Scalar Type Declarations - Dukungan untuk tipe pengembalian dan tipe parameter ditambahkan.
Anonymous Classes - Dukungan untuk anonim ditambahkan.
Zero cost asserts - Dukungan untuk biaya nol menegaskan ditambahkan.
PHP 7 menggunakan Zend Engine 3.0 baru untuk meningkatkan kinerja aplikasi hampir dua kali lipat dan konsumsi memori 50% lebih baik daripada PHP 5.6. Ini memungkinkan untuk melayani lebih banyak pengguna secara bersamaan tanpa memerlukan perangkat keras tambahan. PHP 7 dirancang dan difaktorkan ulang dengan mempertimbangkan beban kerja saat ini.
Sesuai dengan tim Zend , ilustrasi berikut menunjukkan perbandingan kinerja PHP 7 vs PHP 5.6 dan HHVM 3.7 pada aplikasi populer berbasis PHP.
Magento 1.9
PHP 7 membuktikan dirinya lebih dari dua kali lebih cepat, dibandingkan dengan PHP 5.6 saat menjalankan transaksi Magento.
Drupal 7
PHP 7 membuktikan dirinya lebih dari dua kali lebih cepat, dibandingkan dengan PHP 5.6 saat menjalankan transaksi Drupal.
Wordpress 3.6.0
PHP 7 membuktikan dirinya lebih dari dua kali lebih cepat dibandingkan dengan PHP 5.6 saat menjalankan transaksi Wordpress.
Perbandingan Bahasa Dinamis
Cobalah Opsi Online
Kami telah menyiapkan lingkungan Pemrograman PHP secara online, sehingga Anda dapat mengkompilasi dan menjalankan semua contoh yang tersedia secara online. Ini memberi Anda kepercayaan pada apa yang Anda baca dan memungkinkan Anda untuk memverifikasi program dengan opsi yang berbeda. Jangan ragu untuk memodifikasi contoh apa pun dan menjalankannya secara online.
Coba contoh berikut menggunakan kompiler online kami yang tersedia di CodingGround.
<html> <head> <title>Online PHP Script Execution</title> </head> <body> <?php echo "<h1>Hello, PHP!</h1>"; ?> </body> </html>
Untuk sebagian besar contoh yang diberikan dalam tutorial ini, Anda akan menemukan file Try itopsi di bagian kode situs web kami di sudut kanan atas yang akan membawa Anda ke kompiler online. Jadi gunakan saja dan nikmati pembelajaran Anda.
Untuk mengembangkan dan menjalankan halaman Web PHP, tiga komponen penting perlu diinstal pada sistem komputer Anda.
Web Server- PHP bekerja dengan hampir semua perangkat lunak Server Web, termasuk Microsoft's Internet Information Server (IIS) tetapi yang paling sering digunakan adalah Apache Server. Unduh Apache gratis di sini -http://httpd.apache.org/download.cgi
Database- PHP PHP bekerja dengan hampir semua perangkat lunak database, termasuk Oracle dan Sybase tetapi yang paling umum digunakan adalah database MySQL. Unduh MySQL gratis di sini -http://www.mysql.com/downloads/
PHP Parser- Untuk memproses instruksi skrip PHP, parser harus diinstal untuk menghasilkan keluaran HTML yang dapat dikirim ke Browser Web. Tutorial ini akan memandu Anda cara menginstal parser PHP di komputer Anda.
Instalasi PHP Parser
Sebelum Anda melanjutkan, penting untuk memastikan bahwa Anda memiliki pengaturan lingkungan yang tepat pada mesin Anda untuk mengembangkan program web Anda menggunakan PHP. Simpan file php berikut di folder htdocs Apache.
phpinfo.php
<?php
phpinfo();
?>
Ketik alamat berikut ke dalam kotak alamat browser Anda.
http://127.0.0.1/phpinfo.php
Jika ini menampilkan halaman yang menunjukkan informasi terkait instalasi PHP Anda, itu berarti Anda telah menginstal PHP dan Webserver dengan benar. Jika tidak, Anda harus mengikuti prosedur yang diberikan untuk menginstal PHP di komputer Anda.
Bagian ini akan memandu Anda untuk menginstal dan mengkonfigurasi PHP pada empat platform berikut -
Instalasi PHP di Linux atau Unix dengan Apache
Instalasi PHP di Mac OS X dengan Apache
Instalasi PHP pada Windows NT / 2000 / XP dengan IIS
Instalasi PHP pada Windows NT / 2000 / XP dengan Apache
Konfigurasi Apache
Jika Anda menggunakan Apache sebagai Server Web, maka bagian ini akan memandu Anda untuk mengedit File Konfigurasi Apache.
Periksa di sini - Konfigurasi PHP di Apache Server
Konfigurasi File PHP.INI
File konfigurasi PHP, php.ini, adalah cara terakhir dan langsung untuk memengaruhi fungsionalitas PHP.
Periksa di sini - Konfigurasi File PHP.INI
Konfigurasi Windows IIS
Untuk mengkonfigurasi IIS pada mesin Windows Anda, Anda dapat merujuk Manual Referensi IIS yang dikirimkan bersama dengan IIS.
Di PHP 7, fitur baru, deklarasi tipe Skalar, telah diperkenalkan. Deklarasi tipe skalar memiliki dua opsi -
coercive - koersif adalah mode default dan tidak perlu ditentukan.
strict - mode ketat harus diisyaratkan secara eksplisit.
Jenis parameter fungsi berikut dapat diterapkan menggunakan mode di atas -
- int
- float
- bool
- string
- interfaces
- array
- callable
Contoh - Mode Koersif
<?php
// Coercive mode
function sum(int ...$ints) {
return array_sum($ints);
}
print(sum(2, '3', 4.1));
?>
Ini menghasilkan output browser berikut -
9
Contoh - Mode Ketat
<?php
// Strict mode
declare(strict_types=1);
function sum(int ...$ints) {
return array_sum($ints);
}
print(sum(2, '3', 4.1));
?>
Ini menghasilkan output browser berikut -
Fatal error: Uncaught TypeError: Argument 2 passed to sum() must be of the type integer, string given, ...
Di PHP 7, fitur baru, Return type declarationstelah diperkenalkan. Deklarasi tipe pengembalian menentukan tipe nilai yang harus dikembalikan oleh suatu fungsi. Tipe berikut untuk tipe kembalian bisa dideklarasikan.
- int
- float
- bool
- string
- interfaces
- array
- callable
Contoh - Jenis Pengembalian yang Valid
<?php
declare(strict_types = 1);
function returnIntValue(int $value): int {
return $value;
}
print(returnIntValue(5));
?>
Ini menghasilkan output browser berikut -
5
Contoh - Jenis Pengembalian Tidak Valid
<?php
declare(strict_types = 1);
function returnIntValue(int $value): int {
return $value + 1.0;
}
print(returnIntValue(5));
?>
Ini menghasilkan output browser berikut -
Fatal error: Uncaught TypeError: Return value of returnIntValue() must be of the type integer, float returned...
Di PHP 7, fitur baru, null coalescing operator (??)telah diperkenalkan. Ini digunakan untuk menggantikanternaryoperasi dalam hubungannya dengan fungsi isset (). ItuNulloperator coalescing mengembalikan operan pertamanya jika ada dan bukan NULL; jika tidak, ia mengembalikan operan keduanya.
Contoh
<?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);
?>
Ini menghasilkan output browser berikut -
not passed
not passed
not passed
Di PHP 7, fitur baru, operator pesawat luar angkasa telah diperkenalkan. Ini digunakan untuk membandingkan dua ekspresi. Ini mengembalikan -1, 0 atau 1 ketika ekspresi pertama masing-masing kurang dari, sama dengan, atau lebih besar dari ekspresi kedua.
Contoh
<?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/>");
?>
Ini menghasilkan output browser berikut -
0
-1
1
0
-1
1
0
-1
1
Konstanta array sekarang dapat ditentukan menggunakan define()fungsi. Di PHP 5.6, mereka hanya dapat didefinisikan menggunakanconst kata kunci.
Contoh
<?php
//define a array using define function
define('animals', [
'dog',
'cat',
'bird'
]);
print(animals[1]);
?>
Ini menghasilkan output browser berikut -
cat
Kelas anonim sekarang dapat didefinisikan menggunakan kelas baru. Kelas anonim dapat digunakan sebagai pengganti definisi kelas lengkap.
Contoh
<?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");
?>
Ini menghasilkan output browser berikut -
My first Log Message
Closure::call()metode ditambahkan sebagai cara singkat untuk mengikat sementara lingkup objek ke penutupan dan memanggilnya. Ini jauh lebih cepat dalam performa dibandingkan denganbindTo dari PHP 5.6.
Contoh - Pra 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());
?>
Ini menghasilkan output browser berikut -
1
Contoh - PHP 7+
<?php
class A {
private $x = 1;
}
// PHP 7+ code, Define
$value = function() {
return $this->x;
};
print($value->call(new A));
?>
Ini menghasilkan output browser berikut -
1
PHP 7 memperkenalkan Filtered unserialize()berfungsi untuk memberikan keamanan yang lebih baik saat menghapus serial objek pada data yang tidak tepercaya. Ini mencegah kemungkinan injeksi kode dan memungkinkan pengembang untuk memasukkan kelas yang dapat dibatalkan serialnya ke daftar putih.
Contoh
<?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);
?>
Ini menghasilkan output browser berikut -
1
2
Di PHP7, file IntlCharkelas ditambahkan, yang berupaya untuk mengekspos fungsionalitas ICU tambahan. Kelas ini mendefinisikan sejumlah metode dan konstanta statis, yang dapat digunakan untuk memanipulasi karakter unicode. Anda harus memilikiIntl ekstensi dipasang sebelum menggunakan kelas ini.
Contoh
<?php
printf('%x', IntlChar::CODEPOINT_MAX);
print (IntlChar::charName('@'));
print(IntlChar::ispunct('!'));
?>
Ini menghasilkan output browser berikut -
10ffff
COMMERCIAL AT
true
Dalam PHP 7, dua fungsi baru berikut diperkenalkan untuk menghasilkan bilangan bulat dan string yang aman secara kriptografis dengan cara lintas platform.
random_bytes() - Menghasilkan byte pseudo-random yang aman secara kriptografis.
random_int() - Menghasilkan bilangan bulat pseudo-random yang aman secara kriptografis.
random_bytes ()
random_bytes () menghasilkan string dengan panjang arbitrer dari byte acak kriptografi yang sesuai untuk penggunaan kriptografi, seperti saat membuat garam, kunci atau vektor inisialisasi.
Sintaksis
string random_bytes ( int $length )
Parameter
length - Panjang string acak yang harus dikembalikan dalam byte.
Kembalikan Nilai
Mengembalikan string yang berisi jumlah byte acak yang aman secara kriptografis yang diminta.
Kesalahan / Pengecualian
Jika sumber keacakan yang sesuai tidak dapat ditemukan, Exception akan dilempar.
Jika parameter yang diberikan tidak valid, a TypeError akan terlempar.
Jika diberikan panjang byte yang tidak valid, Error akan muncul.
Contoh
<?php
$bytes = random_bytes(5);
print(bin2hex($bytes));
?>
Ini menghasilkan output browser berikut -
54cc305593
random_int ()
random_int() menghasilkan bilangan bulat acak kriptografi yang cocok untuk digunakan di mana hasil yang tidak bias sangat penting.
Sintaksis
int random_int ( int $min , int $max )
Parameter
min - Nilai terendah yang akan dikembalikan, yang harus PHP_INT_MIN atau lebih tinggi.
max - Nilai tertinggi yang akan dikembalikan, yang harus kurang dari atau sama dengan PHP_INT_MAX.
Kembalikan Nilai
Mengembalikan bilangan bulat acak yang aman secara kriptografis dalam rentang min hingga maks, inklusif.
Kesalahan / Pengecualian
Jika sumber keacakan yang tepat tidak dapat ditemukan, sebuah Exception akan terlempar.
Jika parameter yang diberikan tidak valid, a TypeError akan terlempar.
Jika maks kurang dari min, sebuah Error akan terlempar.
Contoh
<?php
print(random_int(100, 999));
print(" ");
print(random_int(-1000, 0));
?>
Ini menghasilkan output browser berikut -
614
-882
Expectationsadalah peningkatan yang kompatibel ke belakang ke fungsi assert () yang lebih lama. Ekspektasi memungkinkan pernyataan tanpa biaya dalam kode produksi, dan memberikan kemampuan untuk menampilkan pengecualian khusus saat pernyataan gagal. assert () sekarang adalah konstruksi bahasa, di mana parameter pertama adalah ekspresi yang dibandingkan dengan string atau Boolean yang akan diuji.
Arahan konfigurasi untuk assert ()
Pengarahan | Nilai default | Nilai yang memungkinkan |
---|---|---|
zend.assertions | 1 | 1 - menghasilkan dan mengeksekusi kode (mode pengembangan) 0 - menghasilkan kode tetapi melompati kode itu saat runtime -1 - jangan menghasilkan kode (mode produksi) |
assert.exception | 0 | 1 - throw, jika pernyataan gagal, baik dengan melempar objek yang disediakan sebagai pengecualian atau dengan melempar yang baru AssertionError menolak jika pengecualian tidak diberikan. 0 - gunakan atau buat Throwable seperti yang dijelaskan di atas, tetapi hanya menghasilkan peringatan berdasarkan objek itu daripada membuangnya (kompatibel dengan perilaku PHP 5) |
Parameter
assertion- Penegasan. Dalam PHP 5, ini harus berupa string yang akan dievaluasi atau Boolean yang akan diuji. Di PHP 7, ini juga dapat berupa ekspresi apa pun yang mengembalikan nilai, yang akan dieksekusi dan hasilnya digunakan untuk menunjukkan apakah pernyataan berhasil atau gagal.
description - Deskripsi opsional yang akan disertakan dalam pesan kegagalan, jika pernyataan gagal.
exception - Dalam PHP 7, parameter kedua bisa berupa a Throwable objek alih-alih string deskriptif, dalam hal ini adalah objek yang akan dilempar, jika pernyataan gagal dan assert.exception direktif konfigurasi diaktifkan.
Kembalikan Nilai
FALSE jika pernyataannya salah, TRUE jika tidak.
Contoh
<?php
ini_set('assert.exception', 1);
class CustomError extends AssertionError {}
assert(false, new CustomError('Custom Error Message!'));
?>
Ini menghasilkan output browser berikut -
Fatal error: Uncaught CustomError: Custom Error Message! in...
Mulai PHP7 dan seterusnya, pernyataan penggunaan tunggal dapat digunakan untuk mengimpor Kelas, fungsi, dan konstanta dari namespace yang sama alih-alih beberapa pernyataan penggunaan.
Contoh
<?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};
?>
Dari PHP 7, penanganan dan pelaporan kesalahan telah diubah. Alih-alih melaporkan kesalahan melalui mekanisme pelaporan kesalahan tradisional yang digunakan oleh PHP 5, sekarang sebagian besar kesalahan ditangani dengan membuang pengecualian Kesalahan. Mirip dengan pengecualian, Pengecualian kesalahan ini menggelembung hingga mencapai blok tangkapan pertama yang cocok. Jika tidak ada blok yang cocok, maka pengendali pengecualian default dipasang denganset_exception_handler()akan dipanggil. Jika tidak ada penangan pengecualian default, maka pengecualian akan diubah menjadi kesalahan fatal dan akan ditangani seperti kesalahan tradisional.
Karena hierarki Error tidak diperpanjang dari Exception, kode yang menggunakan blok catch (Exception $ e) {...} untuk menangani pengecualian yang tidak tertangkap di PHP 5 tidak akan menangani error tersebut. Blok catch (Error $ e) {...} atau aset_exception_handler() penangan diperlukan untuk menangani kesalahan fatal.
Contoh
<?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());
?>
Ini menghasilkan output browser berikut -
Modulo by zero
PHP 7 memperkenalkan fungsi baru intdiv(), yang melakukan pembagian integer dari operannya dan mengembalikan pembagian tersebut sebagai int.
Contoh
<?php
$value = intdiv(10,3);
var_dump($value);
print(" ");
print($value);
?>
Ini menghasilkan output browser berikut -
int(3)
3
Dari PHP7 +, session_start() function menerima larik opsi untuk mengganti arahan konfigurasi sesi yang disetel php.ini. Pilihan ini mendukungsession.lazy_write, yang secara default aktif dan menyebabkan PHP menimpa file sesi apa pun jika data sesi telah berubah.
Opsi lain yang ditambahkan adalah read_and_close, yang menunjukkan bahwa data sesi harus dibaca dan kemudian sesi harus segera ditutup tanpa perubahan. Misalnya, Setsession.cache_limiter menjadi pribadi dan menyetel panji untuk menutup sesi segera setelah membacanya, menggunakan cuplikan kode berikut.
<?php
session_start([
'cache_limiter' => 'private',
'read_and_close' => true,
]);
?>
Fitur berikut sudah tidak digunakan lagi dan mungkin dihapus dari rilis PHP mendatang.
Konstruktor gaya PHP 4
Konstruktor gaya PHP 4 adalah metode yang memiliki nama yang sama dengan kelas yang mereka definisikan, sekarang tidak digunakan lagi, dan akan dihapus di masa mendatang. PHP 7 akan memancarkan E_DEPRECATED jika konstruktor PHP 4 adalah satu-satunya konstruktor yang ditentukan dalam kelas. Kelas yang mengimplementasikan metode __construct () tidak terpengaruh.
Contoh
<?php
class A {
function A() {
print('Style Constructor');
}
}
?>
Ini menghasilkan output browser berikut -
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...
Panggilan statis ke metode non-statis
Panggilan statis ke metode non-statis tidak digunakan lagi, dan dapat dihapus di masa mendatang.
Contoh
<?php
class A {
function b() {
print('Non-static call');
}
}
A::b();
?>
Ini menghasilkan output browser berikut -
Deprecated: Non-static method A::b() should not be called statically in...
Non-static call
opsi garam password_hash ()
Opsi garam untuk password_hash()fungsi sudah tidak digunakan lagi sehingga para pengembang tidak membuat garam mereka sendiri (biasanya tidak aman). Fungsinya sendiri menghasilkan salt yang aman secara kriptografik, saat tidak ada salt yang disediakan oleh developer - sehingga pembuatan salt custom tidak diperlukan lagi.
capture_session_meta opsi konteks SSL
Itu capture_session_metaOpsi konteks SSL sudah tidak digunakan lagi. Metadata SSL sekarang digunakan melaluistream_get_meta_data() fungsi.
Ekstensi berikut telah dihapus dari PHP 7 dan seterusnya -
- ereg
- mssql
- mysql
- sybase_ct
SAPI berikut telah dihapus dari PHP 7 dan seterusnya -
- aolserver
- apache
- apache_hooks
- apache2filter
- caudium
- continuity
- isapi
- milter
- nsapi
- phttpd
- pi3web
- roxen
- thttpd
- tux
- webjames