Ajax提交表單時(shí)驗(yàn)證碼自動(dòng)驗(yàn)證 php后端驗(yàn)證碼檢測(cè)
本文通過源碼展示如何實(shí)現(xiàn)表單提交前,驗(yàn)證碼先檢測(cè)正確性,不正確則不提交表單,更新驗(yàn)證碼。
1、前端代碼 index.html
<!DOCTYPE html> <html> <head> <title>驗(yàn)證碼提交自驗(yàn)證</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta http-equiv="Content-Language" content="zh-CN" /> </head> <body> <form action="doPost.php" method="POST"> <div class="row"> <label for="username">用戶名</label> <input type="text" name="username" id="username" /> </div> <div class="row"> <label for="mod-captcha-code">驗(yàn)證碼</label> <input name="code" id="mod-captcha-code" size="6" class="zjcaptcha" style="width:80px" type="text"/> <img class="code-img" style="height:30px;width:80px;" src="createcode.php?t=0" onclick="this.src=this.src.substring(0,this.src.indexOf('?')+1)+Math.random();return false;" /> <script type="text/javascript" src="http://www.zjmainstay.cn/jquery/jquery-1.8.2.min.js"></script> <div class="yzmtips" style="color:red"></div> </div> <div class="row"> <input type="submit" value="提交" class="submitBtn"/> </div> </form> <script> (function($){ $(document).ready(function(){ $(".submitBtn").click(function() { var obj = $(this); $.ajax({ url:'checkcode.php', type:'POST', data:{code:$.trim($("input[name=code]").val())}, dataType:'json', async:false, success:function(result) { if(result.status == 1) { obj.parents('form').submit(); //驗(yàn)證碼正確提交表單 }else{ $(".code-img").click(); $(".yzmtips").html('驗(yàn)證碼錯(cuò)誤!'); setTimeout(function(){ $(".yzmtips").empty(); },3000); } }, error:function(msg){ $(".yzmtips").html('Error:'+msg.toSource()); } }) return false; }) }); })(jQuery); </script> </body> </html>
2、后端驗(yàn)證碼檢測(cè) checkcode.php
<?php /** * 用戶驗(yàn)證碼驗(yàn)證文件 * @Author:Zjmainstay * @version : 1.0 * @creatdate: 2013-10-4 */ session_start(); echo json_encode(array('status'=>(int)($_SESSION["CHECKCODE"] == $_POST['code']))); exit;
源碼下載地址:Ajax實(shí)現(xiàn)提交表單時(shí)驗(yàn)證碼自動(dòng)驗(yàn)證
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- thinkphp整合系列之極驗(yàn)滑動(dòng)驗(yàn)證碼geetest功能
- Ajax和PHP正則表達(dá)式驗(yàn)證表單及驗(yàn)證碼
- PHP實(shí)現(xiàn)登陸表單提交CSRF及驗(yàn)證碼
- php生成圖片驗(yàn)證碼-附五種驗(yàn)證碼
- php生成圖形驗(yàn)證碼幾種方法小結(jié)
- php 生成隨機(jī)驗(yàn)證碼圖片代碼
- PHP制作圖形驗(yàn)證碼代碼分享
- PHP5中GD庫(kù)生成圖形驗(yàn)證碼(有漢字)
- PHP生成Gif圖片驗(yàn)證碼
- 如何用php生成扭曲及旋轉(zhuǎn)的驗(yàn)證碼圖片
- php+js實(shí)現(xiàn)的拖動(dòng)滑塊驗(yàn)證碼驗(yàn)證表單操作示例【附源碼下載】
相關(guān)文章
Yii學(xué)習(xí)總結(jié)之?dāng)?shù)據(jù)訪問對(duì)象 (DAO)
本文是YII學(xué)習(xí)總結(jié)系列文章的第二篇,主要向我們介紹了數(shù)據(jù)訪問對(duì)象(DAO),十分的詳細(xì),有需要的小伙伴參考下2015-02-02thinkphp微信開之安全模式消息加密解密不成功的解決辦法
使用thinkphp官方的WeChat包,使用不同模式可以成功,但是安全模式就是不行,現(xiàn)將分析解決結(jié)果做下記錄,對(duì)thinkphp加密解密相關(guān)知識(shí)感興趣的朋友參考下2015-12-12thinkPHP3.2實(shí)現(xiàn)分頁(yè)自定義樣式的方法
這篇文章主要介紹了thinkPHP3.2實(shí)現(xiàn)分頁(yè)自定義樣式的方法,結(jié)合實(shí)例形式分析了thinkPHP3.2針對(duì)底層框架代碼的修改與使用相關(guān)操作技巧,需要的朋友可以參考下2018-01-01Laravel框架定時(shí)任務(wù)2種實(shí)現(xiàn)方式示例
這篇文章主要介紹了Laravel框架定時(shí)任務(wù)2種實(shí)現(xiàn)方式,結(jié)合實(shí)例形式較為詳細(xì)的分析了Laravel框架定時(shí)任務(wù)相關(guān)實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2018-12-12使用PHP和JavaScript判斷請(qǐng)求是否來自微信內(nèi)瀏覽器
這篇文章主要介紹了使用PHP和JavaScript判斷請(qǐng)求是否來自微信內(nèi)瀏覽器,包括在手機(jī)端的程序上使用微信的分享JS腳本的方法,需要的朋友可以參考下2015-08-08php中使用array_filter()函數(shù)過濾空數(shù)組的實(shí)現(xiàn)代碼
這篇文章主要介紹了php中使用array_filter()函數(shù)過濾空數(shù)組的實(shí)現(xiàn)代碼,這是瀏覽PHP手冊(cè)時(shí)無意發(fā)意的一個(gè)有意思的array_filter()函數(shù)用法,需要的朋友可以參考下2014-08-08