Heim > Artikel > Backend-Entwicklung > Welche Verschlüsselungsmethoden gibt es in PHP?
php-Verschlüsselungsmethoden umfassen: 1. MD5-Verschlüsselung (Message Digest-Algorithmus 5); 2. SHA-Verschlüsselung (Secure Hash-Algorithmus); 4. Symmetrische Verschlüsselung (Symmetrische Verschlüsselung); Asymmetrische Verschlüsselung.
Die Betriebsumgebung dieses Tutorials: Windows 10-System, PHP8.1.3-Version, DELL G3-Computer.
PHP ist eine beliebte serverseitige Programmiersprache, die häufig in der Website-Entwicklung und Datenbankverwaltung verwendet wird. Sicherheit ist ein zentraler Aspekt bei der Datenübertragung und -speicherung. Um die Sicherheit sensibler Informationen zu schützen, bietet PHP eine Vielzahl von Verschlüsselungsalgorithmen und -methoden. In diesem Artikel werden mehrere gängige PHP-Verschlüsselungstechnologien vorgestellt.
1. MD5-Verschlüsselung (Message Digest-Algorithmus 5)
MD5 ist ein häufig verwendeter Verschlüsselungsalgorithmus, der Daten beliebiger Länge in eine Zeichenfolge fester Länge umwandeln kann. In PHP kann die MD5-Verschlüsselung über die Funktion md5() implementiert werden.
Beispielcode:
$data="HelloWorld"; $encryptedData=md5($data); echo$encryptedData;
Die MD5-verschlüsselte Zeichenfolge ähnelt einer 32-stelligen Hexadezimalzahl und ist irreversibel, d. h. die Originaldaten können nicht aus der verschlüsselten Zeichenfolge wiederhergestellt werden.
2. SHA-Verschlüsselung (Sicherer Hash-Algorithmus)
SHA ist eine kryptografische Hash-Funktion, die häufig zur Datenintegrität und Sicherheitsüberprüfung verwendet wird. PHP bietet eine Vielzahl von SHA-Algorithmen wie SHA-1, SHA-256, SHA-512 usw. Die SHA-Verschlüsselung kann über die Funktion hash() implementiert werden.
Beispielcode:
$data="HelloWorld"; $encryptedData=hash("sha256",$data); echo$encryptedData;
Die Länge der von SHA verschlüsselten Zeichenfolge variiert je nach Algorithmus. Ähnlich wie MD5 ist die SHA-Verschlüsselung irreversibel.
3. Passwort-Hashing-Verschlüsselung (Hashing mit Salts)
Hash-Verschlüsselung ist eine Einweg-Verschlüsselungsmethode, die häufig zum Speichern von Passwörtern oder anderen sensiblen Informationen verwendet wird. Im Gegensatz zu MD5 und SHA verwendet die Hash-Verschlüsselung normalerweise „Salt“, um die Sicherheit zu erhöhen. Der Salt ist eine zufällig generierte Zeichenfolge, die vor der Verschlüsselung an die Originaldaten angehängt wird. In PHP können Sie die Funktion „password_hash()“ für das Passwort-Hashing verwenden.
Beispielcode:
$password="mypassword"; $options=array('cost'=>12); $encryptedPassword=password_hash($password,PASSWORD_BCRYPT,$options); echo$encryptedPassword;
Die Funktion „password_hash()“ generiert eine Zeichenfolge mit dem Passwort und Salt, die zur späteren Überprüfung in der Datenbank gespeichert wird.
4. Symmetrische Verschlüsselung
Die symmetrische Verschlüsselung verwendet denselben Schlüssel zum Verschlüsseln und Entschlüsseln von Daten. In PHP können Sie die Funktionen „openssl_encrypt()“ und „openssl_decrypt()“ verwenden, um symmetrische Verschlüsselungsvorgänge durchzuführen.
Beispielcode:
$data="HelloWorld"; $key="mykey"; $encryptedData=openssl_encrypt($data,"AES-128-ECB",$key); echo$encryptedData;
Das obige Beispiel verwendet den AES-128-Algorithmus zur Verschlüsselung.
5. Asymmetrische Verschlüsselung
Asymmetrische Verschlüsselung verwendet ein Schlüsselpaar zur Ver- und Entschlüsselung, von denen einer zur Verschlüsselung und der andere zur Entschlüsselung verwendet wird. In PHP können Sie die Funktionen „openssl_private_encrypt()“ und „openssl_public_decrypt()“ verwenden, um asymmetrische Verschlüsselungsvorgänge durchzuführen.
Beispielcode:
$data="HelloWorld"; $privateKey=openssl_pkey_get_private(file_get_contents("private.pem")); openssl_private_encrypt($data,$encryptedData,$privateKey); echo$encryptedData; $publicKey=openssl_pkey_get_public(file_get_contents("public.pem")); openssl_public_decrypt($encryptedData,$decryptedData,$publicKey); echo$decryptedData;
Im obigen Beispiel wird die private Schlüsseldatei über die Funktion openssl_pkey_get_private() abgerufen und anschließend werden die Daten über die Funktion openssl_private_encrypt() verschlüsselt. Verwenden Sie die Funktion openssl_pkey_get_public(), um die öffentliche Schlüsseldatei abzurufen, und entschlüsseln Sie die Daten schließlich mit der Funktion openssl_public_decrypt().
Zusammenfassung:
PHP bietet eine Vielzahl von Verschlüsselungsalgorithmen und -methoden, um die Datensicherheit zu gewährleisten. Die Wahl der geeigneten Verschlüsselungsmethode hängt von der Situation und den Bedürfnissen ab. Hash-Verschlüsselungsverfahren wie MD5 und SHA eignen sich zur Überprüfung der Datenintegrität, während die Passwort-Hash-Verschlüsselung zum Speichern von Passwörtern oder anderen sensiblen Informationen verwendet wird. Für Verschlüsselungsvorgänge bei der Datenübertragung und -speicherung eignen sich symmetrische Verschlüsselung und asymmetrische Verschlüsselung. Basierend auf den tatsächlichen Anforderungen können wir eine geeignete Verschlüsselungstechnologie auswählen, um die Datensicherheit zu erhöhen. .
Das obige ist der detaillierte Inhalt vonWelche Verschlüsselungsmethoden gibt es in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!