Rumah >pembangunan bahagian belakang >tutorial php >Cipta tandatangan daripada Hash_hmac() dan Sha256 dalam PHP
Dalam PHP, adalah amalan keselamatan biasa untuk menggunakan fungsi Hash_hmac() bersama-sama dengan algoritma Sha256 untuk mencipta tandatangan. Kaedah ini boleh membantu mengesahkan integriti dan ketulenan data semasa penghantaran data dan mengelakkan data daripada diganggu atau dipalsukan. Dengan menggabungkan Hash_hmac() dan Sha256, cincang berasaskan kunci selamat boleh dijana, memastikan penghantaran dan pemprosesan data selamat. Dalam artikel ini, kami akan mendalami cara menggunakan Hash_hmac() dan Sha256 dalam PHP untuk membuat tandatangan dan cara menggunakan pendekatan ini untuk meningkatkan keselamatan data.
Kami akan menunjukkan kepada anda cara menggunakan hash_hmac
和 sha256
加密器来创建安全签名
, yang boleh anda simpan dalam pangkalan data atau gunakan dalam borang log masuk anda.
hash_hmac()
php
hash_hmac()
创建一个字母数字键控的秘密哈希值。它利用称为 HMAC
Cipta cincang rahsia berkunci alfanumerik. Ia menggunakan teknologi pengesahan kriptografi yang dipanggil kaedah HMAC
.
Tatabahasa:
hash_hmac($alGo, $data, $key, $binary = false);
$algo
是 hash_hmac 参数之一,用作签名秘密键控哈希值 (String
). $data
, nilai cincang (biasanya kata laluan pengguna). Ia boleh menjadi alfanumerik. $key
是从 HMAC
kaedah yang dijana, iaitu kunci yang anda dapat daripada fungsi, dan kegunaan pengaturcaraan lain. $binary
ialah nilai binari.
Ia melemparkan hex huruf kecil pada TRUE
时返回原始数据,并在 FALSE
.
hash_hmac()
和 sha256
dan sha256
Contoh:
<?php //sha256 is a $algo $PassWord= 'ThisIS123PasswORD' ; //data $secret ="ABCabc"; //$key //false is bool value to check whether the method works or not $hash_it = hash_hmac("sha256", utf8_encode($Password), $secret, false);//all four parameters if(!$hash_it){ //checks true or false echo "Password was not encrypted!"; } echo "Your encrypted signature is:<b> '.$hash_it.' </b>"; ?>
Keluaran:
Your encrypted signature is: '.46e9757dc98f478c28f035cfa871dbd19b5a2bf8273225191bcca78801304813
hash_hmac()
和 base64_encode()
dan base64_encode()
Jika anda mahu tandatangan kriptografi anda lebih selamat, anda juga boleh melaksanakan coretan kod berikut.
Contoh:
<?php $my_sign = "abc123"; $key = TRUE; $base64_encode = base64_encode(hash_hmac('sha256', $my_sign, $key, true)); if(!$base64_encode){ echo "Your signature with the base64_decode(hash_hmac()); failed"; } else{ echo "Your base64_decode(hash_hmac()); encrypted signature is is:<b> $base64_encode.' </b>"; } ?>
Keluaran:
Your base64_decode(hash_hmac()); encrypted signature is is: '.00g0QMQlnluXxijqot60WZf6InDi07b/Mb5lL7eVZ34
hash_hmac()
和 sha256
并应用 hex2bin
/bin2hex
dan sha256
dalam PHP dan gunakan transformasi hex2bin
/bin2hex
hex2bin()
- Fungsi ini menyahkod rentetan binari yang telah dikodkan dalam perenambelasan. bin2hex()
- 使用 bin2hex()
Kaedah menukar rentetan ASCII kepada nilai perenambelasan. Katakan anda mempunyai data kewangan kritikal yang ingin anda enkripsi dan buat kunci untuk pengguna.
Contoh:
<?php $createhashmackey = "2974924872949278487322348237749823"; $bank_acc = "029480247299262947328749287"; $current_bal = $sum * 10000 / 450; $bank_locker_no = 'AC54-A76X'; $last_deposit= $when; $se = hex2bin($createhashmackey); $create_his_signature = $bank_acc . $current_bal. $bank_locker_no . $last_deposit; $enigma = bin2hex(hash_hmac('sha256', $create_his_signature, $se)); echo "The secret signature is.$enigma.";
Keluaran:
The secret signature is.33633066323533383537663538323937373536393764396530343661663336666438636435363631383934363864383966316133633433633965343234336233.
Ini adalah output untuk semua contoh kod dalam artikel ini.
Atas ialah kandungan terperinci Cipta tandatangan daripada Hash_hmac() dan Sha256 dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!