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

WBOY
WBOYOriginal
2023-06-09 10:17:181869Durchsuche

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;
?>

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;
?>

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;
?>

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!

Stellungnahme:
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