Ciri baharu dalam PHP 8: Ditambah pengesahan dan tandatangan

王林
Lepaskan: 2024-03-27 08:22:01
asal
715 orang telah melayarinya

PHP 8 新特性:增加了验证和签名

PHP 8 ialah versi terbaharu PHP, membawa lebih banyak kemudahan dan fungsi kepada pengaturcara. Versi ini mempunyai tumpuan khusus pada keselamatan dan prestasi, dan salah satu ciri baharu yang perlu diberi perhatian ialah penambahan keupayaan pengesahan dan tandatangan. Dalam artikel ini, kita akan melihat dengan lebih dekat ciri baharu ini dan kegunaannya.

Pengesahan dan tandatangan adalah konsep keselamatan yang sangat penting dalam sains komputer. Ia sering digunakan untuk memastikan bahawa data yang dihantar adalah lengkap dan sahih. Pengesahan dan tandatangan menjadi sangat penting apabila berurusan dengan transaksi dalam talian dan maklumat sensitif, kerana jika seseorang dapat mengganggu data, ia boleh menyebabkan kemudaratan yang tidak dapat diramalkan kepada syarikat dan pelanggan.

Dalam PHP 8, terdapat dua sambungan baharu untuk mengendalikan pengesahan dan tandatangan: sodium dan openssl. Sambungan ini memudahkan penggunaan kriptografi moden dan protokol keselamatan dalam PHP.

sambungan natrium

Sodium ialah perpustakaan kriptografi moden yang menyediakan akses API kepada banyak algoritma kriptografi dan fungsi keselamatan. Ia telah menjadi perpustakaan pilihan untuk pembangun yang bekerja dengan kriptografi selamat kerana ia berdasarkan piawaian kriptografi terkini seperti Curve25519 dan Chacha20.

Dalam PHP 7.2, sambungan Sodium telah ditambahkan pada perpustakaan standard PHP dan menjadi sambungan pilihan dalam PHP 7.2. Dalam PHP 8, ia telah menjadi sambungan lalai.

Gunakan sambungan natrium untuk pengesahan

Sambungan natrium menyediakan fungsi yang dipanggil sodium_crypto_sign_detached(), yang boleh digunakan untuk menandatangani data. Tandatangan menjana rentetan tertentu yang boleh digunakan untuk mengesahkan sama ada data telah diganggu.

Berikut ialah contoh menandatangani dan mengesahkan menggunakan fungsi sodium_crypto_sign_detached():

<?php
$data = "hello world";
$keys = sodium_crypto_sign_keypair();

$signature = sodium_crypto_sign_detached($data, $keys['secret']);

if (sodium_crypto_sign_verify_detached($signature, $data, $keys['public'])) {
   echo "签名有效";
} else {
   echo "签名无效";
}
Salin selepas log masuk

Dalam contoh ini, kami mula-mula menjana sepasang kunci awam dan peribadi. Kemudian gunakan fungsi $sodium_crypto_sign_detached() untuk menandatangani rentetan dan menyimpan hasil tandatangan dalam pembolehubah $signature. Akhir sekali, gunakan fungsi $sodium_crypto_sign_verify_detached() untuk mengesahkan bahawa tandatangan itu sah.

Jika tandatangan sah, maka "Tandatangan sah" akan dicetak pada skrin, jika tidak "Tandatangan tidak sah" akan dicetak.

Pengesahan menggunakan sambungan openssl

OpenSSL ialah penyulitan popular dan perpustakaan keselamatan yang menyediakan banyak algoritma penyulitan dan ciri keselamatan. Sambungan OpenSSL telah dibina ke dalam PHP, menjadikannya lebih mudah untuk menggunakan OpenSSL dalam PHP.

Pelanjutan OpenSSL menyediakan fungsi lain yang dipanggil openssl_sign() yang boleh menandatangani data. Begitu juga, sambungan juga menyediakan fungsi openssl_verify() untuk mengesahkan tandatangan.

Berikut ialah contoh menandatangani dan mengesahkan menggunakan fungsi openssl_sign() dan openssl_verify():

<?php
$data = "hello world";
$key = openssl_pkey_new(['digest_alg' => 'sha512']);

openssl_sign($data, $signature, $key);

if (openssl_verify($data, $signature, $key)) {
   echo "签名有效";
} else {
   echo "签名无效";
}
Salin selepas log masuk

Dalam contoh ini, kami mula-mula menjana pasangan kunci awam dan peribadi menggunakan fungsi openssl_pkey_new(). Kemudian gunakan fungsi openssl_sign() untuk menandatangani rentetan dan menyimpan hasil tandatangan dalam pembolehubah $signature. Akhir sekali, gunakan fungsi openssl_verify() untuk mengesahkan bahawa tandatangan itu sah.

Jika tandatangan sah, maka "Tandatangan sah" akan dicetak pada skrin, jika tidak "Tandatangan tidak sah" akan dicetak.

Kesimpulan

Pengesahan dan tandatangan adalah kaedah penting untuk memastikan keselamatan data. Dalam PHP 8, sambungan sodium dan openssl akan memudahkan pengesahan dan tandatangan. Pembangun boleh memanfaatkan ciri baharu ini untuk menyediakan perkhidmatan yang lebih selamat kepada syarikat dan pelanggan. Jika anda seorang pembangun PHP, kami mengesyorkan anda mendalami sambungan sodium dan openssl untuk memaksimumkan keselamatan dan melindungi pengguna anda.

Atas ialah kandungan terperinci Ciri baharu dalam PHP 8: Ditambah pengesahan dan tandatangan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan