舉個簡單的例子,登錄驗證
1.先引入js庫
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script> <script src="http://static.geetest.com/static/tools/gt.js"></script>
2.html代碼
<div style="margin:300px;" > <div id="captcha"></div> <button type="submit" id="login">Login</button> </div>
3.前端驗證
<script>
var handler = function (captchaObj) {
// 將驗證碼加到id為captcha的元素里
captchaObj.appendTo("#captcha");
};
// 獲取驗證碼
$.get("{:U('Home/Index/geetest_show_verify')}", function(data) {
// 使用initGeetest接口
// 參數1:配置參數,與創建Geetest實例時接受的參數一致
// 參數2:回調,回調的第一個參數驗證碼對象,之后可以使用它做appendTo之類的事件
initGeetest({
gt: data.gt,
challenge: data.challenge,
product: "float", // 產品形式
offline: !data.success
}, handler);
},'json');
</script>
4.后端驗證碼生成
/** * geetest生成驗證碼 */ public function geetest_show_verify(){ $geetest_id=C('GEETEST_ID'); $geetest_key=C('GEETEST_KEY'); $geetest=new \Org\Xb\Geetest($geetest_id,$geetest_key); $user_id = "test"; $status = $geetest->pre_process($user_id); $_SESSION['geetest']=array( 'gtserver'=>$status, 'user_id'=>$user_id ); echo $geetest->get_response_str(); }
5.調用驗證
if(!geetest_chcek_verify(I('post.'))){ $this->error('驗證碼錯誤'); die; }
