Laravel 集成 Geetest验证码的方法


Posted in PHP onMay 14, 2018

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 href="http://www.geetest.com/" 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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
MySQL修改密码方法总结
Mar 25 PHP
MySql 按时间段查询数据方法(实例说明)
Nov 02 PHP
PHP学习笔记 用户注册模块用户类以及验证码类
Sep 20 PHP
php对mongodb的扩展(初出茅庐)
Nov 11 PHP
用mysql_fetch_array()获取当前行数据的方法详解
Jun 05 PHP
探讨PHP JSON中文乱码的解决方法详解
Jun 06 PHP
使用PHP如何实现高效安全的ftp服务器(二)
Dec 30 PHP
10个对初学者非常有用的PHP技巧
Apr 06 PHP
php 防止表单重复提交两种实现方法
Nov 03 PHP
php 使用curl模拟ip和来源进行访问的实现方法
May 02 PHP
利用PHPExcel读取Excel的数据和导出数据到Excel
May 12 PHP
Swoole源码中如何查询Websocket的连接问题详解
Aug 30 PHP
PHP 多任务秒级定时器的实现方法
May 13 #PHP
原生JS实现Ajax通过POST方式与PHP进行交互的方法示例
May 12 #PHP
原生JS实现Ajax通过GET方式与PHP进行交互操作示例
May 12 #PHP
ThinkPHP框架实现导出excel数据的方法示例【基于PHPExcel】
May 12 #PHP
Laravel框架实现model层的增删改查(CURD)操作示例
May 12 #PHP
layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例
May 12 #PHP
PHP折半(二分)查找算法实例分析
May 12 #PHP
You might like
通过php添加xml文档内容的方法
2015/01/23 PHP
快速保存网页中所有图片的方法
2006/06/23 Javascript
extjs form textfield的隐藏方法
2008/12/29 Javascript
javascript事件问题
2009/09/05 Javascript
jQuery Ajax使用 全解析
2010/12/15 Javascript
js汉字排序问题 支持中英文混排,兼容各浏览器,包括CHROME
2011/12/20 Javascript
js特殊字符转义介绍
2013/11/05 Javascript
利用js实现前台动态添加文本框,后台获取文本框内容(示例代码)
2013/11/25 Javascript
js获取触发事件元素在整个网页中的绝对坐标(示例代码)
2013/12/13 Javascript
jQuery超赞的评分插件(8款)
2015/08/20 Javascript
JS实现的仿QQ空间图片弹出效果代码
2016/02/23 Javascript
Angular.js 实现数字转换汉字实例代码
2016/07/14 Javascript
深入理解Node.js的HTTP模块
2016/10/12 Javascript
js 性能优化之快速响应的用户界面
2017/02/15 Javascript
微信小程序封装http访问网络库实例代码
2017/05/24 Javascript
js字符限制(字符截取) 一个中文汉字算两个字符
2017/09/12 Javascript
关于Vue背景图打包之后访问路径错误问题的解决
2017/11/03 Javascript
为什么说JavaScript预解释是一种毫无节操的机制详析
2018/11/18 Javascript
使用Angular自定义字段校验指令的方法示例
2019/02/01 Javascript
[45:25]OG vs EG 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
python批量制作雷达图的实现方法
2016/07/26 Python
分享一下如何编写高效且优雅的 Python 代码
2017/09/07 Python
解决在pycharm运行代码,调用CMD窗口的命令运行显示乱码问题
2019/08/23 Python
python 矢量数据转栅格数据代码实例
2019/09/30 Python
在Windows上安装和配置 Jupyter Lab 作为桌面级应用程序教程
2020/04/22 Python
Optimalprint加拿大:在线打印服务
2020/04/03 全球购物
幼儿园校车司机的岗位职责
2014/01/30 职场文书
销售会计岗位职责
2014/03/15 职场文书
竞选学生会演讲稿
2014/04/25 职场文书
退休党员个人对照检查材料思想汇报
2014/09/29 职场文书
青年教师个人总结
2015/02/11 职场文书
该怎么书写道歉信?
2019/07/03 职场文书
MySQL 全文检索的使用示例
2021/06/07 MySQL
Python turtle实现贪吃蛇游戏
2021/06/18 Python
pd.DataFrame中的几种索引变换的实现
2022/06/16 Python
Win10本地连接不见了怎么恢复? win10系统电脑本地连接不见了解决方法
2023/01/09 数码科技