校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Laravel 集成 Geetest驗證碼的方法

Laravel 集成 Geetest驗證碼的方法

熱門標簽:合肥外呼系統app h5 地圖標注 寶安400電話辦理 電銷機器人-快迭智能 高識別電銷機器人 拉薩打電話機器人 沈陽人工智能電銷機器人公司 智能外呼電銷系統 哈爾濱400電話辦理到易號網

Geetest 集成大致過程

  1. 實現登錄的大致邏輯
  2. 注冊一個極驗的帳號
  3. 在 “極驗” 的后臺管理中注冊一個行為驗證
  4. 根據 官方Demo 配置我們的控制器和路由
  5. 根據 官方Demo 配置我們的登錄模板
  6. 測試

Geetest 集成詳細過程

1、實現登錄的大致邏輯

創建控制器 php artisan make:controller GeetestController

編輯控制器 /app/Http/Controllers/GeetestController

?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

/**
* 這是一個集成 Geetest 驗證碼的 Demo 類
*/
class GeetestController extends Controller
{ 
 /**
 * 導入登錄視圖
 */
 public function login() {
  return view('Geetest/login');
 }

 /**
 * 驗證用戶信息
 */
 public function check() {
  return '用戶已經在前端通過了驗證碼驗證, 你可以在這里完善后續的邏輯';
 }
}

視圖就是簡單的表單,省略。

2、省略 => “注冊”

3、省略 => “后臺登錄” => “行為驗證” => 申請一個 id key

4、配置控制器和路由

首先, Demo 給出的核心類庫 是一個類文件叫 class.geetestlib.php, 類名叫 GeetestLib 。我們創建一個類名一樣的控制器來代替它 php artisan make:controller GeetestLib

不要拷貝類,拷貝類里面的內容進來即可

GeetestController 控制器實現邏輯

?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Controllers\GeetestLib; // 我們創建然后拷貝得來的 GeetestLib 核心庫

/**
* 這是一個集成 Geetest 驗證碼的 Demo 類
*/
class GeetestController extends Controller
{ 
 // 這里配置 id  key
 private $captchaId = "5d467a3cb22a9310837d51720c5251f0";
 private $privateKey = "40764e6b94344f780d4b6b07148c9495";

 /**
 * 導入登錄視圖
 */
 public function login() {
  return view('Geetest/login');
 }

 /**
 * 驗證用戶信息
 */
 public function check() {
  return '用戶已經在前端通過了驗證碼驗證, 你可以在這里完善后續的邏輯';
 }

 /**
 * 實現驗證功能: 直接復制官方demo提供得
 */
 public function startCaptchaServlet() {
  // 這里使用配置的 id  key
  $GtSdk = new GeetestLib($this->captchaId, $this->privateKey);
  session_start();
  
  $data = array(
   "user_id" => "test", # 網站用戶id
   "client_type" => "web", #web:電腦上的瀏覽器;h5:手機上的瀏覽器,包括移動應用內完全內置的web_view;native:通過原生SDK植入APP應用的方式
   "ip_address" => "127.0.0.1" # 請在此處傳輸用戶請求驗證時所攜帶的IP
  );
  
  $status = $GtSdk->pre_process($data, 1);
  $_SESSION['gtserver'] = $status;
  $_SESSION['user_id'] = $data['user_id'];
  echo $GtSdk->get_response_str();
 }
}

配置路由 /routes/web.php

// 集成 Geetest 驗證碼
Route::get('GeetestLogin', 'GeetestController@login'); //登錄頁面
Route::get('GeetestCheck', 'GeetestController@check'); //登錄驗證 (我們沒寫具體邏輯)
Route::get('GeetestStartCaptchaServlet', 'GeetestController@startCaptchaServlet'); // 調用方法啟用驗證碼

5、完善登錄模板 /resources/views/Geetest/login.blade.php

需要導入 jquery (我們用npm run dev編譯的app.js整合了jquery)

需要導入 Demo 給出 gt.js ,我們放在 public/js 下 script src="/js/gt.js">/script>

其實理論上還可以放在 /resouces/assets/js/ 下, 并且在 /resouces/assets/js/app.js 中 require 進來讓它參與被編譯,直接在 public/js 中打包整合生效。

在模板上,需要定義兩個樣式類 .show .hide => 用于 gt.js 操控提示信息的樣式 同樣可以寫進 /resouces/assets/sass/ 下

給 表單提交 “登錄” 按鈕一個id

拷貝 Demo 中提供的前端 邏輯js, 注意綁定下這個按鈕

注意下 .ajax 配置的 url 必須是我們在 web.php 中定義的路有 'GeetestStartCaptchaServlet'

具體代碼

!DOCTYPE html>
html lang="zh-CN">
head>
 meta charset="UTF-8">
 meta name="viewport" content="width=device-width, initial-scale=1.0">

 !-- 這是我們用 npm run dev 編譯后的 css / js -->
 link rel="stylesheet" href="/css/app.css" rel="external nofollow" >
 script src="/js/app.js">/script>

 !-- 這里需要用到兩個樣式 -->
 style>
  .show {
   display: block;
  }
  .hide {
   display: none;
  }
 /style>

 title> Geetest 集成 Demo/title>
/head>
body>
 div class="container">
  div class="row">
   div class="col-lg-12">
    h1 class="text-center">Geetest 集成 Demo
     small>
      a  rel="external nofollow" rel="external nofollow" > Geetest 官方網站 /a>
     /small> 
    /h1>
   /div>
   div class="col-lg-12">
    form method="GET" action="/GeetestCheck">
     div class="form-group">
      label for="exampleInputEmail1">模擬郵箱地址/label>
      input type="email" class="form-control" id="exampleInputEmail1" aria-describedby="emailHelp" placeholder="請輸入郵箱...">
      small id="emailHelp" class="form-text text-muted">我們不會公開您的郵箱/small>
     /div>
     div class="form-group">
      label for="exampleInputPassword1">模擬密碼/label>
      input type="password" class="form-control" id="exampleInputPassword1" placeholder="請輸入密碼...">
     /div>
     div class="form-group">
      div id="embed-captcha">/div>
      p id="wait" class="show">正在加載驗證碼....../p>
      p id="notice" class="hide">請先完成驗證/p>
     /div>
     !-- 這里需要綁定一個按鈕 -->
     button type="submit" class="btn btn-primary" id="embed-submit">登錄/button>
    /form>
   /div>
  /div>
 /div>

 !-- 引用 gt.js -->
 script src="/js/gt.js">/script>
 !-- 直接復制官方Demo里的js代碼 -->
 script>
  var handlerEmbed = function (captchaObj) {
   $("#embed-submit").click(function (e) {
    var validate = captchaObj.getValidate();
    if (!validate) {
     $("#notice")[0].className = "show";
     setTimeout(function () {
      $("#notice")[0].className = "hide";
     }, 2000);
     e.preventDefault();
    }
   });
   // 將驗證碼加到id為captcha的元素里,同時會有三個input的值:geetest_challenge, geetest_validate, geetest_seccode
   captchaObj.appendTo("#embed-captcha");
   captchaObj.onReady(function () {
    $("#wait")[0].className = "hide";
   });
   // 更多接口參考:http://www.geetest.com/install/sections/idx-client-sdk.html
  };
  $.ajax({
   // 獲取id,challenge,success(是否啟用failback)
   url: "/GeetestStartCaptchaServlet", // 加隨機數防止緩存
   type: "get",
   dataType: "json",
   success: function (data) {
    console.log(data);
    // 使用initGeetest接口
    // 參數1:配置參數
    // 參數2:回調,回調的第一個參數驗證碼對象,之后可以使用它做appendTo之類的事件
    initGeetest({
     gt: data.gt,
     challenge: data.challenge,
     new_captcha: data.new_captcha,
     product: "embed", // 產品形式,包括:float,embed,popup。注意只對PC版驗證碼有效
     offline: !data.success // 表示用戶后臺檢測極驗服務器是否宕機,一般不需要關注
     // 更多配置參數請參見:http://www.geetest.com/install/sections/idx-client-sdk.html#config
    }, handlerEmbed);
   }
  });
 /script>
/body>
/html>

測試成功

可以優化的地方

最好不要用一個 “控制器” 充當核心類庫, 應該把GeetestLib 想辦法集成到另一個地方去

視圖模板上的 js css 應該寫在 resources/assets 里面參與生成 app.css app.js 的編譯

具體登錄邏輯我們沒寫。應該還可以在登錄驗證 check() 方法再確認一次 Geetest驗證 是否成功,可以參考 Demo

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 使用 laravel sms 構建短信驗證碼發送校驗功能
  • Laravel5.2使用Captcha生成驗證碼實現登錄(session巨坑)
  • laravel5.4生成驗證碼的實例講解
  • laravel中短信發送驗證碼的實現方法
  • laravel5.4生成驗證碼的代碼
  • 在 Laravel 中 “規范” 的開發短信驗證碼發送功能
  • Laravel下生成驗證碼的類
  • 用Laravel Sms實現laravel短信驗證碼的發送的實現
  • Laravel框架驗證碼類用法實例分析

標簽:山東 威海 泰州 林芝 巴中 成都 梅州 張家口

巨人網絡通訊聲明:本文標題《Laravel 集成 Geetest驗證碼的方法》,本文關鍵詞  Laravel,集成,Geetest,驗證,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel 集成 Geetest驗證碼的方法》相關的同類信息!
  • 本頁收集關于Laravel 集成 Geetest驗證碼的方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久蜜桃一区二区| 中文字幕制服丝袜成人av| 欧美午夜精品久久久久久孕妇| 国产v综合v亚洲欧| 国产欧美日产一区| 波多野结衣中文字幕一区| 久久综合久久综合久久综合| 亚洲自拍另类综合| 欧美中文字幕一区| 石原莉奈一区二区三区在线观看| 色激情天天射综合网| 一区二区三区久久| 欧美一二三区在线观看| 麻豆成人av在线| 精品国产乱码久久久久久浪潮| 石原莉奈一区二区三区在线观看| 欧美视频一区在线| 日韩激情在线观看| 久久久综合九色合综国产精品| 麻豆精品在线视频| 中文字幕免费不卡| 欧美人伦禁忌dvd放荡欲情| 亚洲444eee在线观看| 91精品国产色综合久久| 韩国成人在线视频| 中文字幕一区二区三区四区不卡| 一本久久精品一区二区| 亚洲成av人片www| 日韩午夜小视频| 99精品在线观看视频| 一区二区视频免费在线观看| 91麻豆国产香蕉久久精品| 亚洲国产sm捆绑调教视频 | 亚洲人成人一区二区在线观看 | 精品系列免费在线观看| 久久久精品国产99久久精品芒果| 国产+成+人+亚洲欧洲自线| 中文一区在线播放| 精品1区2区3区| 91在线国产福利| 久久成人久久爱| 午夜天堂影视香蕉久久| 国产日产欧美一区二区视频| 97超碰欧美中文字幕| 天堂va蜜桃一区二区三区| 久久奇米777| 欧美日韩高清在线播放| 国产麻豆精品在线观看| 亚洲欧美激情一区二区| 精品久久久久香蕉网| 在线国产电影不卡| 丁香一区二区三区| 国内精品国产成人国产三级粉色 | 国产欧美一区二区在线观看| 99免费精品在线观看| 久久国产麻豆精品| 视频一区二区三区入口| 亚洲色图清纯唯美| 国产精品欧美一区二区三区| 欧美情侣在线播放| 欧美色老头old∨ideo| 99天天综合性| 99久久精品免费看国产 | 色先锋资源久久综合| 粉嫩aⅴ一区二区三区四区五区| 日韩精品一二区| 五月婷婷久久综合| 日本在线不卡一区| 蜜臀av一区二区| 免费在线一区观看| 日本网站在线观看一区二区三区| 亚洲综合在线视频| 亚洲小说春色综合另类电影| 国产精品视频在线看| 国产亚洲欧美色| 亚洲国产精品精华液2区45| 久久婷婷国产综合国色天香 | 欧美一区二区美女| 91精品国产aⅴ一区二区| 欧美午夜精品久久久久久孕妇| 91论坛在线播放| 欧美日韩免费观看一区三区| www.亚洲在线| 色噜噜偷拍精品综合在线| 色综合天天综合网天天看片| 国产乱子伦视频一区二区三区| 国产一区二区免费在线| 国产精品1区二区.| 99精品视频在线观看| 色婷婷av一区二区三区软件 | 九九视频精品免费| 国产一区二区三区在线观看免费 | 成人在线一区二区三区| 国产精品18久久久久久久网站| 国产91精品免费| 在线观看一区不卡| 欧美一区二视频| 亚洲国产精品99久久久久久久久| 亚洲图片你懂的| 天天操天天干天天综合网| 极品美女销魂一区二区三区免费| 精品在线亚洲视频| 色综合色综合色综合色综合色综合 | 91网上在线视频| 7799精品视频| 国产精品日韩精品欧美在线| 中文字幕一区日韩精品欧美| 亚洲欧美综合网| 麻豆精品视频在线观看| 国产成人在线看| 欧美日韩精品三区| 亚洲同性同志一二三专区| 捆绑调教一区二区三区| 成人毛片在线观看| 91精品国产综合久久精品性色| 久久综合99re88久久爱| 亚洲精品一卡二卡| 国产成人免费xxxxxxxx| 欧美三级视频在线观看| 久久久欧美精品sm网站 | 亚洲狼人国产精品| 国产精品羞羞答答xxdd| 久久超级碰视频| 欧美性色黄大片手机版| 亚洲国产精品成人久久综合一区| 五月婷婷色综合| 欧美在线三级电影| 亚洲欧美另类久久久精品2019| 精品一区二区三区免费播放| 免费一级欧美片在线观看| 99久久久精品| 国产精品久久久久aaaa| 国内欧美视频一区二区 | 国产精品久久久久永久免费观看| 偷窥国产亚洲免费视频| 久久99日本精品| 911精品国产一区二区在线| 亚洲人成在线观看一区二区| 自拍av一区二区三区| 久久久99久久精品欧美| 亚洲色图制服诱惑 | 91丨九色丨蝌蚪丨老版| 久久久久久免费网| 另类小说图片综合网| 337p亚洲精品色噜噜| 亚洲午夜精品在线| 欧美日韩国产另类一区| 亚洲成人综合网站| 4438x成人网最大色成网站| 亚洲第一精品在线| 555夜色666亚洲国产免| 午夜精品一区二区三区三上悠亚| 一本色道**综合亚洲精品蜜桃冫 | 亚洲图片欧美色图| 欧美综合亚洲图片综合区| 亚洲色图都市小说| 欧美天天综合网| 丝袜美腿一区二区三区| 欧美日韩高清在线| 久久国产精品无码网站| 9色porny自拍视频一区二区| 日本一区二区动态图| 粉嫩av一区二区三区在线播放| 国产精品麻豆欧美日韩ww| 成人avav影音| 性久久久久久久| 日韩一区二区免费视频| 国产成人精品影院| 亚洲精品中文字幕乱码三区| 99久久精品国产精品久久| 樱桃国产成人精品视频| 9191成人精品久久| 国产精品一区二区三区四区| 日韩精品一区二区三区在线观看 | 国产午夜亚洲精品午夜鲁丝片| 国产一区欧美日韩| 中文字幕日韩精品一区 | 在线免费观看成人短视频| 视频一区中文字幕| 亚洲国产精品v| 日韩午夜在线影院| 91成人在线精品| 国产一区二区精品久久91| 国产精品网站在线播放| 欧洲精品中文字幕| 国产盗摄精品一区二区三区在线 | 亚洲一区二区三区视频在线播放| 欧美日韩一级二级| 粉嫩蜜臀av国产精品网站| 亚洲福利电影网| 国产精品色婷婷久久58| 欧美久久一区二区| 国产宾馆实践打屁股91| 午夜精品成人在线视频| 精品播放一区二区| 欧美女孩性生活视频| 黄一区二区三区| 亚洲免费在线播放| 国产精品视频麻豆| 精品国产伦一区二区三区观看方式 |