Heim Backend-Entwicklung PHP-Tutorial Methoden zur Generierung von PHP-Verifizierungscodes und Lösungen für häufige Probleme

Methoden zur Generierung von PHP-Verifizierungscodes und Lösungen für häufige Probleme

Jun 09, 2023 am 10:17 AM
php 验证码 解决方案

Mit der kontinuierlichen Entwicklung des Internets legen die Menschen immer mehr Wert auf den Datenschutz bei der Anmeldung, Registrierung und anderen Vorgängen, die durch Verifizierungscodes überprüft werden müssen, um böswillige Maschinenangriffe und Registrierungen zu verhindern. Heute werde ich Ihnen die Methode zur Generierung von PHP-Bestätigungscodes und Lösungen für häufige Probleme vorstellen.

1. Methode zur Generierung von Verifizierungscodes

  1. Verwenden Sie die PHP-GD-Bibliothek, um einen Bildverifizierungscode zu generieren.

Die GD-Bibliothek ist eine Grafikverarbeitungsbibliothek in PHP, die viele Grafikbetriebsfunktionen bereitstellt. Mithilfe der GD-Bibliothek können wir schnell Bildverifizierungscodes generieren.

Die Schritte sind wie folgt:

① Initialisieren Sie die Leinwand: Die Funktion imagecreatetruecolor() kann basierend auf den angegebenen Parametern eine Echtfarben-Leinwand erstellen. Beispielsweise erstellt imagecreatetruecolor(120, 40) eine 120 x 40 Pixel große Echtfarben-Leinwand.

② Interferenzhintergrund zeichnen: Verwenden Sie die Funktion imagerectangle(), um einige Interferenzlinien in einer Schleife zu zeichnen, um die Erkennung des Bestätigungscodes durch die Maschine zu erschweren.

③ Generieren Sie eine zufällige Zeichenfolge: Generieren Sie eine Zeichenfolge zufälliger Zeichenfolgen als Zeichen im Verifizierungscodebild durch Zufallsfunktionen (rand() und mt_rand()).

④ Zeichnen Sie die Zeichen des Bestätigungscodes auf die Leinwand: Verwenden Sie die Funktion imagechar(), um eine zufällige Zeichenfolge auf die Leinwand zu zeichnen.

⑤ Geben Sie das Bild des Bestätigungscodes an den Browser aus: Verwenden Sie die Funktion header(), um den Inhaltstyp auf image/png oder image/jpeg festzulegen, und verwenden Sie die Funktion imagepng() oder imagejpeg(), um die Leinwand an den Browser auszugeben Browser zur Anzeige.

Das Folgende ist ein einfacher Code zur Generierung von Verifizierungscodes der PHP-GD-Bibliothek:

<?php
session_start();
// 创建画布
$img = imagecreatetruecolor(120, 40);
//生成干扰线
for ($i = 0; $i < 5; $i++) {
    $color = imagecolorallocate($img, rand(0, 255), rand(0, 255), rand(0, 255));
    imageline($img, rand(0, 120), rand(0, 40), rand(0, 120), rand(0, 40), $color);
}
//生成随机验证码
$code = '';
for ($i = 0; $i < 4; $i++) {
    $code .= rand(0, 9);
}
//绘制验证码
$font = 'arial.ttf';
$text_color = imagecolorallocate($img, rand(0, 255), rand(0, 255), rand(0, 255));
imagettftext($img, 18, rand(-10, 10), 10, 24, $text_color, $font, $code);
//输出验证码图片到浏览器
header('Content-Type: image/png');
imagepng($img);
imagedestroy($img);
//将生成的验证码存储到Session中
$_SESSION['code'] = $code;
?>
Nach dem Login kopieren

2. Verwenden Sie die PHP-GD-Bibliothek, um numerische Verifizierungscodes zu generieren.

Numerische Verifizierungscodes sind einfacher und leichter zu verstehen als alphanumerische gemischte Verifizierungscodes, so viele Websites Verwenden Sie Zahlen als Bestätigungscode. Das Folgende ist ein Codebeispiel, das die PHP-GD-Bibliothek verwendet, um einen digitalen Bestätigungscode zu generieren:

<?php
session_start();
// 创建画布
$image = imagecreatetruecolor(120, 40);
// 生成干扰背景
$gray = imagecolorallocate($image, 200, 200, 200);
imagefill($image, 0, 0, $gray);
for ($i = 0; $i < 50; $i++) {
    $black = imagecolorallocate($image, 0, 0, 0);
    imagesetpixel($image, rand(0, 120), rand(0, 40), $black);
}
// 生成随机数字
$code = '';
for ($i = 0; $i < 4; $i++) {
    $code .= rand(0, 9);
}
// 将验证码写入画布中
$font = 'arial.ttf';
$white = imagecolorallocate($image, 255, 255, 255);
imagettftext($image, 20, 0, 15, 30, $white, $font, $code);
// 将验证码输出到浏览器
header('Content-Type: image/png');
imagepng($image);
imagedestroy($image);
// 存储验证码到Session中
$_SESSION['code'] = $code;
?>
Nach dem Login kopieren

3 Verwenden Sie eine Drittanbieter-Bibliothek, um einen Bestätigungscode zu generieren

Obwohl die gerade erwähnte PHP-GD-Bibliothek leistungsstark ist, hat sie es auch Einige Mängel, wie z. B. das generierte Bestätigungscode-Bild, sind zu einfach und können von Robotern leicht geknackt werden. Daher können wir einige Bibliotheken von Drittanbietern verwenden, um komplexere Bestätigungscodes zu generieren.

Gregwar/Captcha ist beispielsweise eine beliebte Verifizierungscode-Bibliothek eines Drittanbieters, die verschiedene Arten von Verifizierungscode-Bildern generieren kann. Die Verwendungsmethode ist ebenfalls sehr einfach. Sie müssen lediglich die Bibliothek herunterladen, die Datei captcha.php importieren und die Funktion create() aufrufen, um den Bestätigungscode zu generieren.

Das Folgende ist ein Codebeispiel, das die Gregwar/Captcha-Bibliothek verwendet, um einen Verifizierungscode zu generieren:

<?php
session_start();
require_once 'Captcha/autoload.php';
$captcha = new GregwarCaptchaCaptchaBuilder;
//配置验证码参数
$captcha->build(
    120,
    40,
    null, //font color
    true //background image
);

header('Content-Type: image/jpeg');
$captcha->output();
$code = $captcha->getPhrase();

$_SESSION['code'] = $code;
?>
Nach dem Login kopieren

2. Lösungen für häufige Probleme

  1. Das Verifizierungscodemuster ist nicht komplex genug

Wie oben erwähnt, wenn die generierte Verifizierung Das Codemuster ist zu einfach und kann von Robotern leicht geknackt werden. Um dieses Problem zu lösen, können wir verschiedene Rauschpunkte hinzufügen, z. B. Interferenzlinien, Bögen, Hintergrundmuster usw. Der so generierte Verifizierungscode ist komplexer und erhöht die Sicherheit.

  1. Generieren Sie mehrere Bestätigungscodes gleichzeitig

Einige Roboter versuchen, mehrere Bestätigungscodes in einer Sekunde zu generieren, um den Bestätigungscode zu knacken. Um diesen Angriff zu verhindern, können wir eine gewisse Zeitverzögerung hinzufügen. Das heißt, wenn der Roboter häufig Bestätigungscodes übermittelt, können wir ihn eine Zeit lang warten lassen, bevor er ihn erneut übermittelt. Dadurch werden Bot-Angriffe effektiv verhindert.

  1. Die Ablaufzeit des Bestätigungscodes ist unklar

In tatsächlichen Projekten sollte der Bestätigungscode nicht zu lange existieren, da die Sicherheit des Bestätigungscodes mit der Zeit abnimmt. Wir müssen die Ablaufzeit des Bestätigungscodes festlegen (z. B. 30 Sekunden) nach der Generierung des Bestätigungscodes und ihn bei der Übermittlung des Bestätigungscodes überprüfen. Wenn die Ablaufzeit überschritten wird, muss der Bestätigungscode neu generiert werden.

Abschließend müssen wir darauf hinweisen, dass in tatsächlichen Anwendungen neben der Einrichtung des Verifizierungscodeschutzes auch andere Formen von Sicherheitsschutzmaßnahmen erforderlich sind, wie z. B. SQL-Injection, XSS-Angriffe und andere Lösungen, um die Website-Sicherheit besser zu schützen .

Das obige ist der detaillierte Inhalt vonMethoden zur Generierung von PHP-Verifizierungscodes und Lösungen für häufige Probleme. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP erstellt Validatoren CakePHP erstellt Validatoren Sep 10, 2024 pm 05:26 PM

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

CakePHP-Protokollierung CakePHP-Protokollierung Sep 10, 2024 pm 05:26 PM

Die Anmeldung bei CakePHP ist eine sehr einfache Aufgabe. Sie müssen nur eine Funktion verwenden. Sie können Fehler, Ausnahmen, Benutzeraktivitäten und von Benutzern durchgeführte Aktionen für jeden Hintergrundprozess wie Cronjob protokollieren. Das Protokollieren von Daten in CakePHP ist einfach. Die Funktion log() wird bereitgestellt

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein Dec 20, 2024 am 11:31 AM

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

CakePHP-Kurzanleitung CakePHP-Kurzanleitung Sep 10, 2024 pm 05:27 PM

CakePHP ist ein Open-Source-MVC-Framework. Es erleichtert die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich. CakePHP verfügt über eine Reihe von Bibliotheken, um die Überlastung der häufigsten Aufgaben zu reduzieren.

See all articles