Spring Boot 极验验证滑动验证码

article/2025/9/23 4:31:17

概要

基于极验验证官网 java版gt3-java-sdk改编,使用Spring Boot 整合的极验滑动验证,包含form表单登录和ajax登录两种情况。

目录

  • 注册账户获取ID和KEY
  • Demo源码说明
  • Demo演示
  • 源码地址

注册账户获取ID和KEY

1.进入官网注册账户

在这里插入图片描述

2.登录后台选择行为认证

在这里插入图片描述

3.增加认证

在这里插入图片描述

4.输入信息

在这里插入图片描述

5.获取ID和KEY
在这里插入图片描述

Demo源码说明

1.Demo结构

在这里插入图片描述

2.关键代码说明

  • sdk包下类和gt.js为极验验证官方提供

  • GeetestConfig.java:ID和KEY配置位置

    // 填入自己的captcha_id和private_key
    private static final String geetest_id = "978b73ea94b4393026524553045ed2ab";
    private static final String geetest_key = "7cd60bfef0a65a78ace8ba085aad023d";
    private static final boolean newfailback = true;public static final String getGeetest_id() {return geetest_id;
    }public static final String getGeetest_key() {return geetest_key;
    }public static final boolean isnewfailback() {return newfailback;
    }
    
  • GeeTestUtil.java:自定义极验验证工具类,对用户操作结果进行验证

/**** @param httpSession* @param challenge* @param validate* @param seccode* @return*/public static boolean validate(HttpSession httpSession,String challenge, String validate, String seccode){GeetestLib gtSdk = new GeetestLib(GeetestConfig.getGeetest_id(), GeetestConfig.getGeetest_key(),GeetestConfig.isnewfailback());//从session中获取gt-server状态int gt_server_status_code = (Integer) httpSession.getAttribute(gtSdk.gtServerStatusSessionKey);//从session中获取useridString userid = (String)httpSession.getAttribute("userid");//自定义参数,可选择添加HashMap<String, String> param = new HashMap<String, String>();param.put("user_id", userid); //网站用户idparam.put("client_type", "web"); //web:电脑上的浏览器;h5:手机上的浏览器,包括移动应用内完全内置的web_view;native:通过原生SDK植入APP应用的方式param.put("ip_address", "127.0.0.1"); //传输用户请求验证时所携带的IPint gtResult = RESULT_FAIL;boolean flag = false;if (gt_server_status_code == GT_SERVER_STATUS_CODE_OK) {//gt-server正常,向gt-server进行二次验证gtResult = gtSdk.enhencedValidateRequest(challenge, validate, seccode, param);} else {// gt-server非正常情况下,进行failback模式验证System.out.println("failback:use your own server captcha validate");gtResult = gtSdk.failbackValidateRequest(challenge, validate, seccode);System.out.println(gtResult);}return gtResult == RESULT_OK;}
  • GeetTestController.java:注册验证码,获取流水号,加载验证码时调用

     /*** 验证1初始化* @return*/@ResponseBody@GetMapping("register1")public String register1(){GeetestLib gtSdk = new GeetestLib(GeetestConfig.getGeetest_id(), GeetestConfig.getGeetest_key(),GeetestConfig.isnewfailback());String resStr = "{}";String userid = "test";//自定义参数,可选择添加HashMap<String, String> param = new HashMap<String, String>();param.put("user_id", userid); //网站用户idparam.put("client_type", "web"); //web:电脑上的浏览器;h5:手机上的浏览器,包括移动应用内完全内置的web_view;native:通过原生SDK植入APP应用的方式param.put("ip_address", "127.0.0.1"); //传输用户请求验证时所携带的IP//进行验证预处理int gtServerStatus = gtSdk.preProcess(param);//将服务器状态设置到session中httpSession.setAttribute(gtSdk.gtServerStatusSessionKey, gtServerStatus);//将userid设置到session中httpSession.setAttribute("userid", userid);resStr = gtSdk.getResponseStr();return resStr;}/*** 验证2 二次验证* @return*/@ResponseBody@GetMapping("register2")public String register2(){GeetestLib gtSdk = new GeetestLib(GeetestConfig.getGeetest_id(), GeetestConfig.getGeetest_key(),GeetestConfig.isnewfailback());String resStr = "{}";//自定义useridString userid = "test";//自定义参数,可选择添加HashMap<String, String> param = new HashMap<String, String>();param.put("user_id", userid); //网站用户idparam.put("client_type", "web"); //web:电脑上的浏览器;h5:手机上的浏览器,包括移动应用内完全内置的web_view;native:通过原生SDK植入APP应用的方式param.put("ip_address", "127.0.0.1"); //传输用户请求验证时所携带的IP//进行验证预处理int gtServerStatus = gtSdk.preProcess(param);//将服务器状态设置到session中httpSession.setAttribute(gtSdk.gtServerStatusSessionKey, gtServerStatus);//将userid设置到session中httpSession.setAttribute("userid", userid);resStr = gtSdk.getResponseStr();return resStr;}
    
  • LoginController.java:登录验证类,控制验证码和账号密码验证结果

     /***模拟表单登录* @param model* @param geetest_challenge* @param geetest_validate* @param geetest_seccode* @param username1* @param password1* @return*/@RequestMapping("/loginForm")public String loginForm(Model model,String geetest_challenge, String geetest_validate, String geetest_seccode,String username1, String password1){if(!GeeTestUtil.validate(httpSession,geetest_challenge,geetest_validate,geetest_seccode)){model.addAttribute("result","验证失败!!!");return "result";}if("admin1".equals(username1) && "admin1".equals(password1)){model.addAttribute("result","登录成功!!!");}else{model.addAttribute("result","登录失败!!!");}return "result";}/*** 模拟AJAX登录* @param geetest_challenge* @param geetest_validate* @param geetest_seccode* @param username2* @param password2* @return*/@ResponseBody@RequestMapping("/loginAJAX")public String loginAJAX(String geetest_challenge, String geetest_validate, String geetest_seccode,String username2, String password2){if(!GeeTestUtil.validate(httpSession,geetest_challenge,geetest_validate,geetest_seccode)){return "验证失败!!!";}if("admin2".equals(username2) && "admin2".equals(password2)){return "登录成功!!!";}else{return "登录失败!!!";}}
    
  • login.html:登录界面和验证码

    <form action="/login/loginForm" method="post" target="_blank"><h2>大图点击Demo,使用表单进行二次验证</h2><br><div><label for="username1">用户名:</label><input class="inp" id="username1" name="username1" type="text" value="admin1"></div><br><div><label for="password1">密码:</label><input class="inp" id="password1" name="password1" type="password" value="admin1"></div><br><div><label>完成验证:</label><div id="captcha1"><p id="wait1" class="show">正在加载验证码......</p></div></div><br><p id="notice1" class="hide">请先完成验证</p><input class="btn" id="submit1" type="submit" value="提交">
    </form>
    <br><br>
    <hr>
    <form><h2>滑动demo,使用ajax进行二次验证</h2><br><div><label for="username2">用户名:</label><input class="inp" id="username2" type="text" value="admin2"></div><br><div><label for="password2">密码:</label><input class="inp" id="password2" type="password" value="admin2"></div><br><div><label>完成验证:</label><div id="captcha2"><p id="wait2" class="show">正在加载验证码......</p></div></div><br><p id="notice2" class="hide">请先完成验证</p><input class="btn" id="submit2" type="submit" value="提交">
    </form>
    <!-- 注意,验证码本身是不需要 jquery 库,此处使用 jquery 仅为了在 demo 使用,减少代码量 -->
    <script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.js"></script>
    <!-- 引入 gt.js,既可以使用其中提供的 initGeetest 初始化函数 -->
    <script src="gt.js"></script>
    <script>var handler1 = function (captchaObj) {$("#submit1").click(function (e) {var result = captchaObj.getValidate();if (!result) {$("#notice1").show();setTimeout(function () {$("#notice1").hide();}, 2000);e.preventDefault();}});// 将验证码加到id为captcha的元素里,同时会有三个input的值用于表单提交captchaObj.appendTo("#captcha1");captchaObj.onReady(function () {$("#wait1").hide();});// 更多接口参考:http://www.geetest.com/install/sections/idx-client-sdk.html};$.ajax({url: "geetTest/register1?t=" + (new Date()).getTime(), // 加随机数防止缓存type: "get",dataType: "json",success: function (data) {// 调用 initGeetest 初始化参数// 参数1:配置参数// 参数2:回调,回调的第一个参数验证码对象,之后可以使用它调用相应的接口initGeetest({gt: data.gt,challenge: data.challenge,new_captcha: data.new_captcha, // 用于宕机时表示是新验证码的宕机offline: !data.success, // 表示用户后台检测极验服务器是否宕机,一般不需要关注product: "float", // 产品形式,包括:float,popupwidth: "100%"// 更多配置参数请参见:http://www.geetest.com/install/sections/idx-client-sdk.html#config}, handler1);}});var handler2 = function (captchaObj) {$("#submit2").click(function (e) {var result = captchaObj.getValidate();if (!result) {$("#notice2").show();setTimeout(function () {$("#notice2").hide();}, 2000);} else {$.ajax({url: 'login/loginAJAX',type: 'POST',// dataType: 'json',data: {username2: $('#username2').val(),password2: $('#password2').val(),geetest_challenge: result.geetest_challenge,geetest_validate: result.geetest_validate,geetest_seccode: result.geetest_seccode},success: function (data) {alert(data);}})}e.preventDefault();});// 将验证码加到id为captcha的元素里,同时会有三个input的值用于表单提交captchaObj.appendTo("#captcha2");captchaObj.onReady(function () {$("#wait2").hide();});// 更多接口参考:http://www.geetest.com/install/sections/idx-client-sdk.html};$.ajax({url: "geetTest/register2?t=" + (new Date()).getTime(), // 加随机数防止缓存type: "get",dataType: "json",success: function (data) {// 调用 initGeetest 初始化参数// 参数1:配置参数// 参数2:回调,回调的第一个参数验证码对象,之后可以使用它调用相应的接口initGeetest({gt: data.gt,challenge: data.challenge,new_captcha: data.new_captcha, // 用于宕机时表示是新验证码的宕机offline: !data.success, // 表示用户后台检测极验服务器是否宕机,一般不需要关注product: "popup", // 产品形式,包括:float,popupwidth: "100%"// 更多配置参数请参见:http://www.geetest.com/install/sections/idx-client-sdk.html#config}, handler2);}});
    </script>
    

    Demo演示

    1.登录界面,正在加载的验证码

在这里插入图片描述

2.验证码展示

在这里插入图片描述

3.验证成功之后,提交跳转到登录页面,再次点击提交显示验证失败,一个验证码只能使用一次。(AJAX登录同理)

在这里插入图片描述
在这里插入图片描述

源码地址

  • 官网Demo gt3-java-sdk
  • github: git@github.com:hdlxt/lxtDaily.git

http://chatgpt.dhexx.cn/article/OTtqulZW.shtml

相关文章

iOS集成极验行为验证

iOS集成极验行为验证 项目中有使用到极验行为验证 看了下官方的demo&#xff0c;记录下如下的要点&#xff0c;官网文档行为验证 官方验证按钮GT3CaptchaButton的效果图如下&#xff1a; 也可以不使用官方GT3CaptchaButton&#xff0c;而使用自定义的按钮。但它们都要注意三…

Javascript框架库漏洞验证

Javascript框架库漏洞 &#x1f4a8;前言&#x1f4a9;漏洞验证&#x1f440;漏洞描述&#x1f43e;解决办法&#x1f480;免费福利 &#x1f4a8;前言 经常看到漏扫扫出来这个漏洞&#xff0c;查看了网上好多文章都没有正确的验证方法都在扯淡。今天我来点干货记录一下这个漏…

SSL证书文件验证

SSL证书域名验证 SSL证书域名验证方式有三种&#xff1a;自动DNS验证&#xff0c;手工DNS验证&#xff0c;文件验证 自动DNS验证&#xff1a;域名和SSL证书都是同一个供应商购买手工DNS验证&#xff1a;域名和SSL证书不是同一个供应商购买&#xff0c;需要到域名提供方进行解…

stata进行logistic回归内部验证和外部验证

我们既往已经介绍了使用Stata进行logistic回归绘制列线图并做内部验证,不少粉丝发信息问我怎么进行外部验证。今天我们来介绍一下,继续使用我们的不孕症数据(公众号回复:不孕症可以获得该数据)。我们数据先导入看一下 数据有8个指标,最后两个是PSM匹配结果,我们不用理他…

极验点选验证分析

本文分析的是极验点选验证码。 不管自己训练识别模型还是调用第三方识别接口&#xff0c;都需要拿到完成的验证图片。 极验的滑块验证图片是重新拼接的乱序图片。图片是由canvas标签绘制的&#xff0c;可以通过监听canvas断点调试。 接下来看看点选是否与众不同。 文章目录 …

geetest极验验证-java使用笔记

业务场景 在系统业务中&#xff0c;需要想客户发送手机验证码&#xff0c;进行验证后&#xff0c;才能提交。但为了防止不正当的短信发送&#xff08;攻击&#xff0c;恶意操作等&#xff09;&#xff0c;需要在发送短信前添加一个行为验证&#xff08;这里使用的是 极验&…

【原创】Python 极验滑块验证

本文仅供学习交流使用,如侵立删!记一次 极验滑块验证分析并通过 操作环境 win10 、 macPython3.9selenium、seleniumwire分析 最近在做的一个项目登录时会触发一个滑块验证,就长下面这个样子 可以很明显的看出来是极验3代验证,借助之前写阿里云盾的经验使用selenium+pya…

MCU芯片级验证

第一讲 前言 只要是做SOC芯片的项目都需要SOC验证&#xff0c;SOC验证也是芯片验证的重中之重。 在之前做过ahb2apb、ahb2uart的验证之后&#xff0c;这篇文章提到相关内容都很少深入&#xff0c;于是乎&#xff0c;还是后面打算去啃ARM架构&#xff0c;默写代码去了&#xff…

极验验证滑块破解,canvas

前言 请勿用于商务用途哦&#xff0c;仅限于学习&#xff0c;否则后果自负哦 有两篇关于极验验证滑块破解的文章&#xff0c;在此分享一下&#xff1a; https://www.jianshu.com/p/c8df1194b514 https://www.jianshu.com/p/f12679a63b8d 这两篇文章针对不同滑块&#xff0c;有…

极验验证--滑块验证

极验验证–滑块验证 本文通过通过模拟登录极验网站&#xff0c;完成滑块验证 所用语言和相关模块 python3.6seleniumrequestsPIL 极验验证码特点分析 极验验证是一种在计算机领域用于区分自然人和机器人的&#xff0c;通过简单集成的方式&#xff0c;为开发者提供安全、便捷…

vue2.0 + 极验验证

1.极验验证gt.js需要注意的是这两行 window.initGeetest initGeetest; return initGeetest; 网上有博主的文章中是没有这两行的截图的&#xff0c;需要注意。完整的js如下&#xff1a;-------------------------------------------------------------------------------…

更安全的验证方式-极验验证

简介 极验验证是一种在计算机领域区分自然人和机器人的&#xff0c;通过简单集成的方式&#xff0c;为开发者提供安全、便捷的云端验证服务&#xff0c;与以往传统验证不同的是&#xff0c;极验通过分析用户完成拼图过程中的行为特征&#xff0c;通过数据分析来判断是人还是机…

centos7 创建、删除目录软连接

创建/删除目录软连接 ① 目录只能创建软链接 ② 目录创建链接必须用绝对路径&#xff0c;相对路径创建会不成功&#xff0c;会提示&#xff1a;符号连接的层数过多这样的错误 ③ 在链接目标目录中修改文件都会在源文件目录中同步变化 1.创建软连接 创建源目录&#xff1a; …

C#删除目录和目录下的所有文件

方法1&#xff1a;直接删除法 DirectoryInfo di new DirectoryInfo(string Path);di.Delete(true); 注&#xff1a;path是你要删除的非空目录&#xff1b; true&#xff1a;你要删除里面所有的文件&#xff0c;包括文件夹和子文件夹 方法2&#xff1a;层级删除法 /// <…

练习HDFS的访问,创建目录,删除目录--超详细

1、如果连接被拒绝&#xff0c;则输入&#xff1a; source ~/.bash_profile: 2、进入到sbin目录下输入&#xff1a;start-dfs.sh&#xff0c;重启一下。 之后再输入hdfs dfs -ls /&#xff0c;没有出现拒绝连接即可。 3、若需要创建目录&#xff0c;则输入&#xff1a; hdfs…

linux删除目录下文件的几种方法

删除某个目录下的文件 > tree . . └── rumenz├── 1.txt├── 2.txt└── one2 directories, 2 files删除rumenz目录下的所有文件(不删除目录) > rm -f rumenz/* rm: cannot remove ‘rumenz/one’: Is a directory如果是一个目录就跳过提示 使用find删除rumenz…

linux 删除目录下所有指定的子目录

find /var/lib/jenkins/jobs/service-sit-jck-syc/jobs -type d -name "builds" -exec rm -rf {} find 【要搜索的目录】 -type d【d为目录&#xff0c;如果是删除指定文件&#xff0c;就用f】-name “【要删除的目录名】” exec rm -rf {}

bat脚本删除目录下的文件

今天在写脚本的时候有一个场景是需要判断目录是否存在如果存在的话就删除掉这个目录&#xff0c;然后在执行其他操作。 我们需要删除delete目录及其目录下的所有文件 D: set dir delete echo %dir% if exist %dir% ( del /s /q %dir% rd /s /q %dir% ) pause

在 Linux 中删除目录——如何从命令行删除目录和内容

Linux 是著名的开源操作系统,其功能通常在你的开发环境中可用。熟练使用它的基本命令,可以使开发人员的生活变得更加轻松。 在这篇指南中,你将学习如何从 Linux 命令行删除目录和文件。 Linux rm 命令 rm(remove 的缩写)命令非常有用。让我们学习它的语法,并查看一些示…

C++删除目录,包括该目录下所有子目录和文件

目录 一、FindFirstFile 1.函数功能&#xff1a; 2.函数原型&#xff1a; 3.参数&#xff1a; 4.返回值&#xff1a; 5.注意&#xff1a; 二、FindNextFile 1.函数功能&#xff1a; 2.函数原型&#xff1a; 3.参数&#xff1a; 4.返回值&#xff1a; 5.注意&#x…