ホームページ >バックエンド開発 >PHPチュートリアル >PHP イメージ検証コードは JavaScript を使用して検証されます
現在、画像検証は検証のためにバックグラウンドに引き渡されており、クエリ速度に影響を与えているようです。検証のためにJavaScriptに渡すにはどうすればよいですか?
<?php session_start(); //生成验证码图片 Header("Content-type: image/PNG"); $im = imagecreate(44,18); // 画一张指定宽高的图片 $back = ImageColorAllocate($im, 245,245,245); // 定义背景颜色 imagefill($im,0,0,$back); //把背景颜色填充到刚刚画出来的图片中 $vcodes = ""; srand((double)microtime()*1000000); //生成4位数字 for($i=0;$i<4;$i++){ $font = ImageColorAllocate($im, rand(100,255),rand(0,100),rand(100,255)); // 生成随机颜色 $authnum=rand(1,9); $vcodes.=$authnum; imagestring($im, 5, 2+$i*10, 1, $authnum, $font); } $_SESSION['VCODE'] = $vcodes; for($i=0;$i<100;$i++) //加入干扰象素 { $randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255)); imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); // 画像素点函数 } ImagePNG($im); ImageDestroy($im); ?>
<form name="form1" method="post" action="719.php" > <p><label>电脑编号:</label><input name="username" type="text" size="20"></p> <p class="prmt"><label>用户密码:</label><input name="pass" type="password" size="20"> <input type="submit" name="Submit" value="查 询"></p> <p class="prmt"><label>验 证 码:</label><input name="ask" type="text" size="6"><img id="refresh" src="muth.php" onclick="document.getElementById('refresh').src='muth.php'"/></p> </form>
JavaScript 検証は簡単にバイパスまたはクラックされる可能性があるため、推奨されません
ユーザーが操作する検証はすべて信頼性がありません
それで?最初に中央のページにジャンプします。このページでは検証コードが正しいかどうかを判定するだけで、結果を出力するページにジャンプします。そうでない場合は、プロンプトが表示され、元の入力ページに戻ります。
セッションはサーバーに保存されていますが、フロントデスクはどうやってそれを取得できますか?
JavaScript で確認する???
では、なぜ確認コードが必要なのでしょうか?
js 検証に合格しましたが、ユーザーがもう一度クリックして正しい検証コードを再度入力するために戻ってしまうのは望ましくありません。フォームをクリックすると直接検証されます。
ホストさん、送信時に認証コードとユーザー名とパスワードを一緒に送信したのですが、認証コードが正しいかどうかを以前に判断していなかったので、再確認する必要があると心配していましたね。間違って入力した場合は、ユーザー名とパスワードを入力してください。通常、ここでは ajax が使用されます。確認コードの入力ボックスがフォーカスを失ったときに、入力内容を取得し、それが正しい場合はバックグラウンドに渡します。入力ボックスの右側にあるチェック マークをオンにします。そうでない場合は、次の処理ステップのバックグラウンドに移動します。私はすべてについて少ししか知りません
まず第一に、ajax を理解する必要があります。jquery から ajax を学習し始める方が便利で、20 分以内に効果が出ます
http://www.baidu.com/ s?wd=jquery+ ajax 今日、私は他の問題にも苦労しています。完全なコードを書くのを手伝うことはできません...
ajax は完全に壊れています
私も以前この問題に遭遇しましたが、バックグラウンドで認証コードを判断するのが面倒でした。 jsを使いたかったのですが、認証コードが取得できなかったので、セッション内の認証コードを隠しタグに入れてjsを使おうと思いました。取得した認証コードは前回か更新前のもので、どうしても使いにくくて、後で諦めてしまいました。
この問題を注意深く考えてみると、フォーム内の非表示のラベルの値はページの初期化の値ですが、ユーザーに表示されるグラフィカルな検証コードの値は新しく生成されたものであることがわかります。検証コードのセッション値がリセットされるため、一歩遅れています。元の投稿者の質問は、前のネチズンが判断を開始するために ajax を使用することについて述べたものと同じです。具体的なトリガー方法は、ボタンがバウンスしたときと、そのときに入力された検証コードの長さを加えて、ajax イベントを適切にトリガーすることだと思います。