Springboot 集成geetest滑塊驗證碼 全程代碼

最近項目短信發(fā)送被人刷了,加了驗證碼哩簿,感覺不好用宵蕉,改為滑塊驗證,這里記錄下节榜。
1 下載 sdk 羡玛,解壓放到項目里面。


image

GeetestConfig 代碼:

注意要把這里的id 和key 替換成自己注冊的宗苍。這里用的是官網(wǎng)提供的文檔

import javax.swing.text.StyledEditorKit.BoldAction;
/**
 * GeetestWeb配置文件
 * 
 *
 */
public class GeetestConfig {
// 填入自己的captcha_id和private_key
private static final String geetest_id = "002bc30ff1eef93e912f45814945e752";
private static final String geetest_key = "4193a0e3247b82a26f563d595c447b1a";
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;
}
}

StartCaptchaController 加載滑塊代碼:

import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import com.ganjiangps.wangdaibus.config.geetest.sdk.java.GeetestLib;
/**
 * 獲取滑塊 驗證 
 * @author cjm
 *
 */
@Controller
public class StartCaptchaController {
@RequestMapping("/startCaptcha")
public void StartCaptcha(HttpServletRequest request,
HttpServletResponse response) throws IOException{
GeetestLib gtSdk = new GeetestLib(GeetestConfig.getGeetest_id(), GeetestConfig.getGeetest_key(),true);
String resStr = "{}";
// 自定義userid
String userid = "test";
//自定義參數(shù),可選擇添加
HashMap<String, String> param = new HashMap<String, String>(); 
param.put("user_id", userid); //網(wǎng)站用戶id
//param.put("client_type", "web"); //web:電腦上的瀏覽器稼稿;h5:手機上的瀏覽器薄榛,包括移動應(yīng)用內(nèi)完全內(nèi)置的web_view;native:通過原生SDK植入APP應(yīng)用的方式
//param.put("ip_address", "127.0.0.1"); //傳輸用戶請求驗證時所攜帶的IP
// 進行驗證預(yù)處理
int gtServerStatus = gtSdk.preProcess(param);
// 將服務(wù)器狀態(tài)設(shè)置到session中
request.getSession().setAttribute(gtSdk.gtServerStatusSessionKey, gtServerStatus);
// 將userid設(shè)置到session中
request.getSession().setAttribute("geetuserid", userid);
resStr = gtSdk.getResponseStr();
PrintWriter out = response.getWriter();
out.println(resStr);
}
}

VerifyLoginController 驗證代碼:

import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.ganjiangps.wangdaibus.config.geetest.sdk.java.GeetestLib;
/**
 * 驗證測試 Controller
 * @author admin
 *
 */
@Controller
public class VerifyLoginController {
@ResponseBody
@RequestMapping("/verifyLogin")
public Map<String,String> verifyLogin(HttpServletRequest request,
HttpServletResponse response){
GeetestLib gtSdk = new GeetestLib(GeetestConfig.getGeetest_id(), GeetestConfig.getGeetest_key(), 
GeetestConfig.isnewfailback());
String challenge = request.getParameter(GeetestLib.fn_geetest_challenge);
String validate = request.getParameter(GeetestLib.fn_geetest_validate);
String seccode = request.getParameter(GeetestLib.fn_geetest_seccode);
//從session中獲取gt-server狀態(tài)
int gt_server_status_code = (Integer) request.getSession().getAttribute(gtSdk.gtServerStatusSessionKey);
//從session中獲取userid
String userid = (String)request.getSession().getAttribute("geetuserid");
//自定義參數(shù),可選擇添加
HashMap<String, String> param = new HashMap<String, String>(); 
param.put("user_id", userid); //網(wǎng)站用戶id
//param.put("client_type", "web"); //web:電腦上的瀏覽器让歼;h5:手機上的瀏覽器敞恋,包括移動應(yīng)用內(nèi)完全內(nèi)置的web_view;native:通過原生SDK植入APP應(yīng)用的方式
//param.put("ip_address", "127.0.0.1"); //傳輸用戶請求驗證時所攜帶的IP
int gtResult = 0;
if (gt_server_status_code == 1) {
//gt-server正常是越,向gt-server進行二次驗證
gtResult = gtSdk.enhencedValidateRequest(challenge, validate, seccode, param);
System.out.println(gtResult);
} else {
// gt-server非正常情況下耳舅,進行failback模式驗證
System.out.println("failback:use your own server captcha validate");
gtResult = gtSdk.failbackValidateRequest(challenge, validate, seccode);
System.out.println(gtResult);
}
Map<String,String> data = new HashMap<>();
if (gtResult == 1) {
// 驗證成功
data.put("status", "success");
data.put("version", gtSdk.getVersionInfo());
 } else {
// 驗證失敗
data.put("status", "fail");
data.put("version", gtSdk.getVersionInfo());
 }
return data;
}
}

jsp 測試代碼:

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()   "://"
  request.getServerName()   ":"   request.getServerPort()
  path   "/";
%>
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>gt-node-sdk-demo</title>
    <style>
        body {
            margin: 50px 0;
            text-align: center;
            font-family: "PingFangSC-Regular", "Open Sans", Arial, "Hiragino Sans GB", "Microsoft YaHei", "STHeiti", "WenQuanYi Micro Hei", SimSun, sans-serif;
        }
        .inp {
            border: 1px solid #cccccc;
            border-radius: 2px;
            padding: 0 10px;
            width: 278px;
            height: 40px;
            font-size: 18px;
        }
        .btn {
            border: 1px solid #cccccc;
            border-radius: 2px;
            width: 100px;
            height: 40px;
            font-size: 16px;
            color: #666;
            cursor: pointer;
            background: white linear-gradient(180deg, #ffffff 0%, #f3f3f3 100%);
        }
        .btn:hover {
            background: white linear-gradient(0deg, #ffffff 0%, #f3f3f3 100%)
        }
        #captcha1,
        #captcha2 {
            width: 300px;
            display: inline-block;
        }
        .show {
            display: block;
        }
        .hide {
            display: none;
        }
        #notice1,
        #notice2 {
            color: red;
        }
        label {
            vertical-align: top;
            display: inline-block;
            width: 80px;
            text-align: right;
        }
        #wait1, #wait2 {
            text-align: left;
            color: #666;
            margin: 0;
        }
    </style>
</head>
<body>
<h1>極驗驗證SDKDemo</h1>
<hr>
<form action="gt/ajax-validate1" method="post">
    <h2>大圖點擊Demo,使用表單進行二次驗證</h2>
    <br>
    <div>
        <label for="username1">用戶名:</label>
        <input class="inp" id="username1" type="text" value="極驗驗證">
    </div>
    <br>
    <div>
        <label for="password1">密碼:</label>
        <input class="inp" id="password1" type="password" value="123456">
    </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>
<!-- 注意倚评,驗證碼本身是不需要 jquery 庫浦徊,此處使用 jquery 僅為了在 demo 使用,減少代碼量 -->
<script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.js"></script>
<!-- 引入 gt.js天梧,既可以使用其中提供的 initGeetest 初始化函數(shù) -->
<script src="./static/js/geettest/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: "/startCaptcha?t="   (new Date()).getTime(), // 加隨機數(shù)防止緩存
        type: "get",
        dataType: "json",
        success: function (data) {
            // 調(diào)用 initGeetest 初始化參數(shù)
            // 參數(shù)1:配置參數(shù)
            // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象呢岗,之后可以使用它調(diào)用相應(yīng)的接口
            initGeetest({
                gt: data.gt,
                challenge: data.challenge,
                new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機
                offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機冕香,一般不需要關(guān)注
                product: "popup", // 產(chǎn)品形式,包括:float后豫,popup
                width: "100%"
                // 更多配置參數(shù)請參見:http://www.geetest.com/install/sections/idx-client-sdk.html#config
            }, handler1);
        }
    });
</script>
<br><br>
<hr>
<form>
    <h2>滑動demo悉尾,使用ajax進行二次驗證</h2>
    <br>
    <div>
        <label for="username2">用戶名:</label>
        <input class="inp" id="username2" type="text" value="極驗驗證">
    </div>
    <br>
    <div>
        <label for="password2">密碼:</label>
        <input class="inp" id="password2" type="password" value="123456">
    </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>
<script>
    var handler2 = function (captchaObj) {
        $("#submit2").click(function (e) {
            var result = captchaObj.getValidate();
            if (!result) {
                $("#notice2").show();
                setTimeout(function () {
                    $("#notice2").hide();
                }, 2000);
            } else {
                $.ajax({
                    url: 'gt/ajax-validate2',
                    type: 'POST',
                    dataType: 'json',
                    data: {
                        username: $('#username2').val(),
                        password: $('#password2').val(),
                        geetest_challenge: result.geetest_challenge,
                        geetest_validate: result.geetest_validate,
                        geetest_seccode: result.geetest_seccode
                    },
                    success: function (data) {
                        if (data.status === 'success') {
                            alert('登錄成功');
                        } else if (data.status === 'fail') {
                            alert('登錄失敗');
                        }
                    }
                })
            }
            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: "/startCaptcha?t="   (new Date()).getTime(), // 加隨機數(shù)防止緩存
        type: "get",
        dataType: "json",
        success: function (data) {
            // 調(diào)用 initGeetest 初始化參數(shù)
            // 參數(shù)1:配置參數(shù)
            // 參數(shù)2:回調(diào)挫酿,回調(diào)的第一個參數(shù)驗證碼對象构眯,之后可以使用它調(diào)用相應(yīng)的接口
            initGeetest({
                gt: data.gt,
                challenge: data.challenge,
                new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機
                offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機,一般不需要關(guān)注
                product: "popup", // 產(chǎn)品形式早龟,包括:float惫霸,popup
                width: "100%"
                // 更多配置參數(shù)請參見:http://www.geetest.com/install/sections/idx-client-sdk.html#config
            }, handler2);
        }
    });
</script>
</body>
</html>

瀏覽器效果如圖:

image
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市葱弟,隨后出現(xiàn)的幾起案子壹店,更是在濱河造成了極大的恐慌,老刑警劉巖芝加,帶你破解...
    沈念sama閱讀 218,546評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件硅卢,死亡現(xiàn)場離奇詭異,居然都是意外死亡藏杖,警方通過查閱死者的電腦和手機将塑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來制市,“玉大人,你說我怎么就攤上這事弊予∠殚梗” “怎么了?”我有些...
    開封第一講書人閱讀 164,911評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長误褪。 經(jīng)常有香客問我责鳍,道長,這世上最難降的妖魔是什么兽间? 我笑而不...
    開封第一講書人閱讀 58,737評論 1 294
  • 正文 為了忘掉前任历葛,我火速辦了婚禮,結(jié)果婚禮上嘀略,老公的妹妹穿的比我還像新娘恤溶。我一直安慰自己,他們只是感情好帜羊,可當(dāng)我...
    茶點故事閱讀 67,753評論 6 392
  • 文/花漫 我一把揭開白布咒程。 她就那樣靜靜地躺著,像睡著了一般讼育。 火紅的嫁衣襯著肌膚如雪帐姻。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,598評論 1 305
  • 那天奶段,我揣著相機與錄音饥瓷,去河邊找鬼。 笑死痹籍,一個胖子當(dāng)著我的面吹牛呢铆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播词裤,決...
    沈念sama閱讀 40,338評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼刺洒,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了吼砂?” 一聲冷哼從身側(cè)響起逆航,我...
    開封第一講書人閱讀 39,249評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎渔肩,沒想到半個月后因俐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,696評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡周偎,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,888評論 3 336
  • 正文 我和宋清朗相戀三年抹剩,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,013評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡毁渗,死狀恐怖蒜焊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钳踊,我是刑警寧澤衷敌,帶...
    沈念sama閱讀 35,731評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站拓瞪,受9級特大地震影響缴罗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜祭埂,卻給世界環(huán)境...
    茶點故事閱讀 41,348評論 3 330
  • 文/蒙蒙 一面氓、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蛆橡,春花似錦舌界、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至粥血,卻和暖如春柏锄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背复亏。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評論 1 270
  • 我被黑心中介騙來泰國打工趾娃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人缔御。 一個月前我還...
    沈念sama閱讀 48,203評論 3 370
  • 正文 我出身青樓抬闷,卻偏偏與公主長得像,于是被迫代替她去往敵國和親耕突。 傳聞我的和親對象是個殘疾皇子笤成,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,960評論 2 355

推薦閱讀更多精彩內(nèi)容