程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP 極驗驗證碼實例講解

PHP 極驗驗證碼實例講解

編輯:PHP綜合

你能找到這篇文章,說明你對極驗驗證已經不是完全陌生的了,所有廢話我就不多說了,直接開始表說如何使用它,不過在此之前呢,先粘貼幾個你可能會用得到的網址:

官網:http://www.geetest.com/

官方文檔:http://www.geetest.com/install/sections/idx-basic-introduction.html

github:https://github.com/GeeTeam/gt-php-sdk.git

如何使用:

首先要確認前端使用頁面,比如登陸頁面

<script src="http://code.jquery.com/jquery-1.12.3.min.js"></script>
<script src="http://static.geetest.com/static/tools/gt.js"></script>  

1.在登陸頁面訪問引入類庫:

如果您的網站使用https,則只需要將引入極驗庫的地方換成https協議即可,不需要更改其它地方。例如更換成以下代碼即可:

<script src="https://code.jquery.com/jquery-1.12.3.min.js"></script>
<script src="https://static.geetest.com/static/tools/gt.js"></script>  

2.初始化前端

下面的代碼需要在頁面加載後就執行,如果你使用jQuery,可以寫在$(function(){});內

$.ajax({
  // 獲取id,challenge,success(是否啟用failback)
  url: "../web/StartCaptchaServlet.php?t=" + (new Date()).getTime(), // 加隨機數防止緩存
  type: "get",
  dataType: "json",
  success: function (data) {
    // 使用initGeetest接口
    // 參數1:配置參數
    // 參數2:回調,回調的第一個參數驗證碼對象,之後可以使用它做appendTo之類的事件
    initGeetest({
      gt: data.gt,
      challenge: data.challenge,
      product: "popup", // 產品形式,包括:float,embed,popup。注意只對PC版驗證碼有效
      offline: !data.success // 表示用戶後台檢測極驗服務器是否宕機,與SDK配合,用戶一般不需要關注
    }, handlerPopup);
  }
});
  

上面代碼的意思是說,頁面加載後,需要到你指定的URL地址上獲得驗證碼信息,至於上面的URL地址“../web/StartCaptchaServlet.php”裡面寫了什麼內容,這個我們在服務器端代碼部署會詳細說明。

但是需要說明的是,上面的代碼裡有一個回調函數叫“handlerPopup”,這個函數是你需要驗證碼的真正初始化代碼:如下:

// 代碼詳細說明
var handlerPopup = function (captchaObj) {
  // 注冊提交按鈕事件,比如在登陸頁面的登陸按鈕
  $("#popup-submit").click(function () {
    // 此處省略在登陸界面中,獲取登陸數據的一些步驟
    
    // 先校驗是否點擊了驗證碼
    var validate = captchaObj.getValidate();
    if (!validate) {
      alert('請先完成驗證!');
      return;
    }
    // 提交驗證碼信息,比如登陸頁面,你需要提交登陸信息,用戶名和密碼等登陸數據
    $.ajax({
      url: "../web/VerifyLoginServlet.php",
      type: "post",
      // dataType: "json",
      data: {
        // 用戶名和密碼等其他數據,自己獲取,不做演示
        username:username,
        password:password,
        // 驗證碼數據,這些數據不用自己獲取
        // 這是二次驗證所需的三個值
        // 當然,你也可以直接設置驗證碼單獨校驗,省略其他信息
        geetest_challenge: validate.geetest_challenge,
        geetest_validate: validate.geetest_validate,
        geetest_seccode: validate.geetest_seccode
      },
      // 這裡是正確返回處理結果的處理函數
      // 假設你就返回了1,2,3
      // 當然,正常情況是返回JSON數據
      success: function (result) {
        // 1表示驗證碼驗證失敗
        if (result == "1") {
          alert("驗證碼驗證失敗!");
        }else if (result == "2") {
          alert("用戶名或密碼錯誤!");
        }else if (result == "3") {
          alert("登陸成功!");
          // 登陸成功了,可以在這裡做其他處理
        }else{
          alert("登陸錯誤!");
        }
      }
    });
  });
  // 彈出式需要綁定觸發驗證碼彈出按鈕
  // 比如在登陸頁面,這個觸發按鈕就是登陸按鈕
  captchaObj.bindOn("#popup-submit");
   
  // 將驗證碼加到id為captcha的元素裡
  // 驗證碼將會在下面指定的元素中顯示出來
  captchaObj.appendTo("#popup-captcha");
   
  // 更多接口參考:http://www.geetest.com/install/sections/idx-client-sdk.html
};
  

至此,前端的所有設置都寫完了,官方的說明文檔:http://www.geetest.com/install/sections/idx-client-sdk.html

 3.服務器端部署(PHP) 

在第一步中,我們設置了一個這樣的地址“../web/StartCaptchaServlet.php”,在這個地址裡邊寫什麼呢:

<?php
// 引入文件
require_once dirname(dirname(__FILE__)) . '/lib/class.geetestlib.php';
require_once dirname(dirname(__FILE__)) . '/config/config.php';
// 實例化,實例化的參數在config中配置,分別是:驗證ID 和 驗證Key,如何獲取下面會說。
$GtSdk = new GeetestLib(CAPTCHA_ID, PRIVATE_KEY);
session_start();
// 這個是用戶的標識,或者說是給極驗服務器區分的標識,如果你項目沒有預先設置,可以像下面這樣設置:
if(!isset($_SESSION['user_id'])){
  $_SESSION['user_id']=uniqid();// 生成一個唯一ID
}
$user_id = $_SESSION['user_id'];
// 或者,你就直接寫成:
// $user_id = "test";
 
// 生成驗證碼信息,並返回給客戶端
$status = $GtSdk->pre_process($user_id);
$_SESSION['gtserver'] = $status;
$_SESSION['user_id'] = $user_id;
echo $GtSdk->get_response_str();
?>
  

如何獲取 驗證ID 和 驗證Key :

1.從 驗證後台 注冊賬號
2.添加驗證,可以獲取一組當前驗證的ID/Key
3.將ID和Key分別替換到config.php文件中的captcha_id/private_key變量的值 

4.點擊提交按鈕之後的服務端校驗(二次驗證)

比如上面說的,用戶登錄時,你把用戶名和密碼和驗證碼信息都提交到服務器了,這個時候,你就可以做校驗了:

<?php
// 引入文件
require_once dirname(dirname(__FILE__)) . '/lib/class.geetestlib.php';
require_once dirname(dirname(__FILE__)) . '/config/config.php';
session_start();
$GtSdk = new GeetestLib(CAPTCHA_ID, PRIVATE_KEY);
 
// 比如你設置了一個驗證碼是否驗證通過的標識
$code_flag=false;
 
// 這裡獲取你之前設置的user_id,傳送給極驗服務器做校驗
$user_id = $_SESSION['user_id'];
if ($_SESSION['gtserver'] == 1) {
  $result = $GtSdk->success_validate($_POST['geetest_challenge'], $_POST['geetest_validate'], $_POST['geetest_seccode'], $user_id);
  if ($result) {
    // 驗證碼驗證成功
    $code_flag=true;
  }
}else{
  if ($GtSdk->fail_validate($_POST['geetest_challenge'],$_POST['geetest_validate'],$_POST['geetest_seccode'])) {
     // 驗證碼驗證成功
    $code_flag=true;
  }
}
 
// 如果驗證碼驗證成功,再進行其他校驗
if($code_flag){
  // 其他驗證操作
  // 用戶名不對時,返回2,其他錯誤返回3,等等。。。。
}else{
  // 驗證碼驗證失敗,返回1,這裡和上面相呼應,當然我的項目沒有簡單的返回1,而是返回了JSON數據
  echo 1;
  exit(-1);
}
?>
  

感謝你的閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved