hash_hmac()
[ Funktionen in PHP ]
hash_hmac()
Erstellen Sie einen alphanumerisch verschlüsselten geheimen Hash. Es nutzt HMAC
eine kryptografische Authentifizierungstechnologie namens Methode.
Grammatik:
hash_hmac($algo, $data, $key, $binary = false);
-
$algo
Ist einer der hash_hmac-Parameter und wird als Signatur-Geheimschlüssel-Hash (String
) verwendet. -
$data
, ein Hashwert (normalerweise das Passwort des Benutzers). Es kann alphanumerisch sein. -
$key
wird aus der MethodeHMAC
generiert , die der Schlüssel ist, den Sie von der Funktion erhalten, und für andere Programmierzwecke. -
Der letzte Parameter
$binary
ist ein Binärwert.
Es TRUE
gibt die Rohdaten zurück, wenn und FALSE
wirft hexadezimale Kleinbuchstaben, wenn .
hash_hmac()
[Verwendung von und in PHP sha256
]
Beispiel:
<?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>";
?>
Ausgabe:
Your encrypted signature is: '.46e9757dc98f478c28f035cfa871dbd19b5a2bf8273225191bcca78801304813
[Verwenden hash_hmac()
und base64_encode()
]
Wenn Sie möchten, dass Ihre kryptografischen Signaturen sicherer sind, können Sie auch den folgenden Codeausschnitt ausführen.
Beispiel:
<?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>";
}
?>
Ausgabe:
Your base64_decode(hash_hmac()); encrypted signature is is: '.00g0QmqlnluXxijqot60WZf6InDi07b/Mb5lL7eVZ34
hash_hmac()
[Verwenden und in PHP sha256
und anwenden hex2bin
/ bin2hex
konvertieren]
hex2bin()
– Diese Funktion dekodiert eine binäre Zeichenfolge, die hexadezimal kodiert wurde.bin2hex()
– Verwenden Siebin2hex()
die Methode, um eine ASCII-Zeichenfolge in einen Hexadezimalwert umzuwandeln.
Nehmen wir an, Sie verfügen über wichtige Finanzdaten, die Sie verschlüsseln und einen Schlüssel für den Benutzer erstellen möchten.
Beispiel:
<?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.";
Ausgabe:
The secret signature is.33633066323533383537663538323937373536393764396530343661663336666438636435363631383934363864383966316133633433633965343234336233.
Dies ist die Ausgabe aller Codebeispiele in diesem Tutorial.