PHP Portal » PHP Handbuch » openssl_verify

Werbung

openssl_verify


(PHP 4 >= 4.0.4, PHP 5)

openssl_verifyÜberprüft eine Signatur

Beschreibung

int openssl_verify ( string $data , string $signature , mixed $pub_key_id [, int $signature_alg ] )

Die Funktion openssl_verify() überprüft die Korrektheit der Unterschrift signature für die angegebenen Daten data mit Hilfe des öffentlichen Schlüssels pub_key_id . Das muss der passende öffentliche zum privaten Schlüssel sein, der für die Unterschrift benutzt wurde.

Parameter-Liste

data

signature

pub_key_id

signature_alg

Standard ist OPENSSL_ALGO_SHA1. Für weitere Informationen siehe Signatur-Algorithmen.

Rückgabewerte

Gibt für eine korrekte Signatur 1 zurück, 0 für eine unkorrekte und -1 falls ein Fehler aufgetreten ist.

Changelog

Version Beschreibung
5.0.0 Der Parameter signature_alg wurde hinzugefügt.

Beispiele

PHP Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// Annahme: $data und $signature enthalten die Daten und die Unterschrift // holen des öffentlichen Schlüssels aus dem Zertifikat und vorbereiten $fp = fopen("/src/openssl-0.9.6/demos/sign/cert.pem", "r"); $cert = fread($fp, 8192); fclose($fp); $pubkeyid = openssl_get_publickey($cert); // feststellen, ob die Unterschrift ok ist oder nicht $ok = openssl_verify($data, $signature, $pubkeyid); if ($ok == 1) { echo "gut"; } elseif ($ok == 0) { echo "schlecht"; } else { echo "Mist, Fehler beim überprüfen der Signatur"; } // Löschen des Schlüssels aus dem Speicher openssl_free_key($pubkeyid);

Siehe auch