PHP イメージ検証コードは JavaScript を使用して検証されます

WBOY
リリース: 2016-06-23 14:19:21
オリジナル
1036 人が閲覧しました

この投稿は cyyjm によって最終編集されました: 2013-08-15 11:48:37

現在、画像検証は検証のためにバックグラウンドに引き渡されており、クエリ速度に影響を与えているようです。検証のためにJavaScriptに渡すにはどうすればよいですか?
php によって生成されるページ コードは次のとおりです:
<?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> 
ログイン後にコピー

このように、バックグラウンドでは session_start() を開いて $_SESSION['VCODE; を使用することで検証コードが正しいかどうかを判断できます。 ']。
検証にPHPのバックグラウンドを必要とせずに、JavaScriptを介して検証を行うにはどうすればよいですか。

ディスカッションへの返信 (解決策)

JavaScript 検証は簡単にバイパスまたはクラックされる可能性があるため、推奨されません

ユーザーが操作する検証はすべて信頼性がありません

それで?最初に中央のページにジャンプします。このページでは検証コードが正しいかどうかを判定するだけで、結果を出力するページにジャンプします。そうでない場合は、プロンプトが表示され、元の入力ページに戻ります。

セッションはサーバーに保存されていますが、フロントデスクはどうやってそれを取得できますか?

JavaScript で確認する???
では、なぜ確認コードが必要なのでしょうか?

js 検証に合格しましたが、ユーザーがもう一度クリックして正しい検証コードを再度入力するために戻ってしまうのは望ましくありません。フォームをクリックすると直接検証されます。

ホストさん、送信時に認証コードとユーザー名とパスワードを一緒に送信したのですが、認証コードが正しいかどうかを以前に判断していなかったので、再確認する必要があると心配していましたね。間違って入力した場合は、ユーザー名とパスワードを入力してください。通常、ここでは ajax が使用されます。確認コードの入力ボックスがフォーカスを失ったときに、入力内容を取得し、それが正しい場合はバックグラウンドに渡します。入力ボックスの右側にあるチェック マークをオンにします。そうでない場合は、次の処理ステップのバックグラウンドに移動します。私はすべてについて少ししか知りません

まず第一に、ajax を理解する必要があります。jquery から ajax を学習し始める方が便利で、20 分以内に効果が出ます

http://www.baidu.com/ s?wd=jquery+ ajax 今日、私は他の問題にも苦労しています。完全なコードを書くのを手伝うことはできません...

ajax は完全に壊れています

私も以前にこの問題に遭遇し、面倒でした。バックグラウンドで認証コードを判断します。 jsを使いたかったのですが、認証コードが取得できなかったので、セッション内の認証コードを隠しタグに入れてjsを使おうと思いました。取得した認証コードは前回か更新前のもので、どうしても使いにくくて、後で諦めてしまいました。


私も以前この問題に遭遇しましたが、バックグラウンドで認証コードを判断するのが面倒でした。 jsを使いたかったのですが、認証コードが取得できなかったので、セッション内の認証コードを隠しタグに入れてjsを使おうと思いました。取得した認証コードは前回か更新前のもので、どうしても使いにくくて、後で諦めてしまいました。
この問題を注意深く考えてみると、フォーム内の非表示のラベルの値はページの初期化の値ですが、ユーザーに表示されるグラフィカルな検証コードの値は新しく生成されたものであることがわかります。検証コードのセッション値がリセットされるため、一歩遅れています。元の投稿者の質問は、前のネチズンが判断を開始するために ajax を使用することについて述べたものと同じです。具体的なトリガー方法は、ボタンがバウンスしたときと、そのときに入力された検証コードの長さを加えて、ajax イベントを適切にトリガーすることだと思います。

たとえば、4 桁の確認コードの場合、ボタンがポップアップしたときに長さが判断され、長さが 4 に達すると、入力が正しいかどうかが ajax を使用して判断されます。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート