您好,登錄后才能下訂單哦!
這篇文章主要介紹了在AspNetCore中如何使用極驗做行為認證,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
先上效果圖
極驗的流程
極驗官方文檔地址 https://docs.geetest.com/install/deploy/server/csharp
簡單說明一下極驗的驗證流程
引用官方的圖片
?向服務器發送請求獲取驗證參數
?客戶端sdk完成驗證
?由客戶端sdk驗證數據提交服務器二次驗證
在netcore中使用極驗
在我查看官方的sdk過后,發現不是特別好用,根據極驗的流程寫了一套適用于netcore的極驗sdk 開源地址 已經發了nuget包 搜索sharpplug.geetest即可
使用方式很簡單,下面通過一個例子來進行講解
使用命令dotnet new mvc
創建一個mvc項目
下一步使用命令dotnet add package sharpplug.geetest
安裝nuget包
打開startup文件在ConfigureServices中配置geetest服務
我在極驗申請了一個測試用的id和key 大家可以直接測試使用
public void ConfigureServices(IServiceCollection services) { services.Configure<CookiePolicyOptions>(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. options.CheckConsentNeeded = context => true; options.MinimumSameSitePolicy = SameSiteMode.None; }); // GeetestOptions中配置id 與 key services.AddGeetest(opt=>{ opt.Id = "e2697c763685a34be93a7d255ee06b59"; opt.Key = "7882a2d954106041a731f5e10038982a"; }); services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1); }
完成獲取驗證參數與二次驗證的類是GeetestManager,它主要有兩個方法
獲取驗證參數方法是Register,它主要有三個參數 userid(用戶標識) clientType(客戶端類型) 與 ipaddress(客戶端ip) 關于參數的細節大家可以去參閱極驗文檔
Task<GeeTestRegisterResult> Register(string userId = null, string clientType = "unknown", string ipAddress = "unknown")
二次驗證方法 Validate 參數為
?offline 是否離線驗證(獲取驗證參數失敗時)
?UserId 用戶標識
?Challenge
?Seccode
?Validate
Task<bool> Validate(GeetestValidateInput input)
下面打開HomeController添加獲取驗證參數方法,記得注入GeetestManager
private readonly GeetestManager _geetestManager; public HomeController(GeetestManager geetestManager) { _geetestManager = geetestManager; } public async Task<GeeTestRegisterResult> GeetestRegister() { return await _geetestManager.Register(clientType: "web", ipAddress: "127.0.0.1"); }
下面在HomeController中加入二次驗證
public async Task<bool> GeetestValidate(GeetestValidateInput input) { return await _geetestManager.Validate(input); }
服務端部分已經完成,下面打開index.cshtml先引用gt.js
<script type="text/javascript" src="https://static.geetest.com/static/tools/gt.js"></script>
然后添加html元素
<h3>Getest</h3> <div id="geetestform"> <input type="hidden" name="geetest_challenge" id="geetest_challenge"> <input type="hidden" name="geetest_validate" id="geetest_validate"> <input type="hidden" name="geetest_seccode" id="geetest_seccode"> </div> <button class="form-control btn-default" id="validate">點我驗證</button>
極驗有一個初始化的過程,先調用獲取驗證參數api進行初始化極驗
$(function() { $.ajax({ url: "/home/GeetestRegister", type: "get", dataType: "json", success: function(data) { // 使用offline判斷是否是離線驗證 offline = !data.success; initGeetest({ // 以下配置參數來自服務端 SDK gt: data.gt, challenge: data.challenge, offline: !data.success, new_captcha: true, product: "float", width: "100%" },function(){ // 初始化元素 captchaObj.appendTo(document.getElementById('geetestform')); }) } }); });
這時運行項目已經可以看到極驗的驗證表單了并且已經可以進行驗證,但是還需要添加點擊按鈕事件進行二次驗證
$("#validate").click(() => { var validate = captchaObj.getValidate(); if (validate === undefined || !validate) { alert("請進行驗證"); return; } $.ajax({ url: "/home/GeetestValidate", method:"post", data: { offline: offline, challenge: validate.geetest_challenge, validate: validate.geetest_validate, seccode: validate.geetest_seccode }, success: function(res) { if (res) { alert("二次校驗狀態成功! 重置驗證狀態"); captchaObj.reset(); } else { alert("二次校驗狀態返回失敗! 重置驗證狀態"); captchaObj.reset(); } } }); });
感謝你能夠認真閱讀完這篇文章,希望小編分享的“在AspNetCore中如何使用極驗做行為認證”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。