#この記事の動作環境: Windows10 システム、php 7、thinkpad t480 コンピューター。 検証コードは日常生活で非常に一般的です。検証コードを使用すると、次のような多くの利点があります: 悪意によるパスワードのクラッキングを防止します。たとえば、ユーザー情報を取得するために、一部のハッカーはさまざまな手段を使用してサーバーにデータを送信し、推測されたユーザー情報の正確性を確認します。 悪意のあるチケット操作やフォーラムのフラッディングを防ぎます。このフラッディング現象は、Tieba などの投稿が絶えず送信されるフォーラムでは長い間存在していました。現在、Baidu Tiebaではユーザーの投稿に期限が設けられており、一定期間内に投稿が多すぎると投稿を続けることができなくなります。 悪意のあるリクエストを防止します。たとえば、ユーザーがフォーム情報を送信すると、バックグラウンドでデータ情報が継続的に要求されるため、サーバー リソースが無駄になり、悪意のある攻撃が発生します。 ######楽しい。これは個人的な意見ですが、フォームを送信するときに、興味深い確認コードのメソッドに遭遇すると、ユーザーの Web サイトへの愛着が高まる可能性があります。 ユーザー情報を取得します。これは今日の現場ではよくあることです。たとえば、サイトにアカウントを登録する場合、正常に登録するには携帯電話の確認コードを渡す必要があります。ユーザーの電話番号を取得した後、Web サイトは携帯電話番号の所有者にマーケティング情報を送信します。 それでは、検証コードログイン機能を実装するにはどうすればよいでしょうか?一緒に見てみましょう! 環境構成: PHP の GD 拡張ライブラリをローカルにインストールするだけで使用できます。確認方法は、PHPファイルを作成し、ファイル内に1c54a2ccadef45a7573e3649bdfd6f57と記述し、ファイルにアクセスし、GDライブラリがインストールされていれば使用可能です。 特定のコード実装: 1. まず、検証コードphp メソッドによる検証コード ログインの実装: 1. 検証コードを表示する HTML ページを作成します; 2. PHP ファイルを作成し、フロントエンド ページから渡された検証コード情報を受け入れます; 3. PHP ファイルを生成するための確認コード。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登陆</title> </head> <body> <form action="./login.php" method="post"> <img src="image_captcha.php" onclick="this.src='image_captcha.php?'+new Date().getTime();" width="200" height="200"><br/> <input type="text" name="captcha" placeholder="请输入图片中的验证码"><br/> <input type="submit" value="验证"> </form> </body> </html>を表示する HTML ページを作成します。2. 渡された検証コード情報を受け入れるための PHP ファイルを作成します。フロントエンド ページから
<?php /** * 接受用户登陆时提交的验证码 */ session_start(); //1. 获取到用户提交的验证码 $captcha = $_POST["captcha"]; //2. 将session中的验证码和用户提交的验证码进行核对,当成功时提示验证码正确,并销毁之前的session值,不成功则重新提交 if(strtolower($_SESSION["captchaimg"]) == strtolower($captcha)){ echo "验证码正确!"; $_SESSION["captcha"] = ""; }else{ echo "验证码提交不正确!"; }3. PHP ファイルを生成するための検証コードを作成します
<?php /** * 字母+数字的验证码生成 */ // 开启session session_start(); //1.创建黑色画布 $image = imagecreatetruecolor(100, 30); //2.为画布定义(背景)颜色 $bgcolor = imagecolorallocate($image, 255, 255, 255); //3.填充颜色 imagefill($image, 0, 0, $bgcolor); // 4.设置验证码内容 //4.1 定义验证码的内容 $content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; //4.1 创建一个变量存储产生的验证码数据,便于用户提交核对 $captcha = ""; for ($i = 0; $i < 4; $i++) { // 字体大小 $fontsize = 10; // 字体颜色 $fontcolor = imagecolorallocate($image, mt_rand(0, 120), mt_rand(0, 120), mt_rand(0, 120)); // 设置字体内容 $fontcontent = substr($content, mt_rand(0, strlen($content)), 1); $captcha .= $fontcontent; // 显示的坐标 $x = ($i * 100 / 4) + mt_rand(5, 10); $y = mt_rand(5, 10); // 填充内容到画布中 imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor); } $_SESSION["captcha"] = $captcha; //4.3 设置背景干扰元素 for ($$i = 0; $i < 200; $i++) { $pointcolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imagesetpixel($image, mt_rand(1, 99), mt_rand(1, 29), $pointcolor); } //4.4 设置干扰线 for ($i = 0; $i < 3; $i++) { $linecolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imageline($image, mt_rand(1, 99), mt_rand(1, 29), mt_rand(1, 99), mt_rand(1, 29), $linecolor); } //5.向浏览器输出图片头信息 header('content-type:image/png'); //6.输出图片到浏览器 imagepng($image); //7.销毁图片 imagedestroy($image);推奨される学習:
php トレーニング
以上がPHPで認証コードログインを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。