C#滑动拼图验证码实现笔记

简介: C# 是一个现代的、通用的、面向对象的编程语言,它是由微软(Microsoft)开发的,由 Ecma 和 ISO 核准认可的。突发奇想,动手开发一个C#滑动拼图验证码,下面是我开发过程的记录。

前言

C# 是一个现代的、通用的、面向对象的编程语言,它是由微软(Microsoft)开发的,由 Ecma 和 ISO 核准认可的。突发奇想,动手开发一个C#滑动拼图验证码,下面是我开发过程的记录。


准备工作

本文使用IIS搭建环境,同时确保项目运行正常。

3.PNG


目录结构

4.PNG


核心代码

  • noramal.html
<!doctype html><html><head><metacharset="utf-8"><title>凯格行为验证码 - Net C# demo</title><linkrel="stylesheet"href="./style/demo.css"/><!--将以下域名替换成你的“应用服务器域名”将以下 appid 替换成你的 AppID服务器域名和appid在你的应用管理中获取示例:<script src="captcha.js?appid=xxx"></script>--><scriptsrc="captcha.js?appid=appId"></script><script>kg.captcha({
// 绑定显示区域bind: "#captchaBox",
// 验证成功事务处理success: function (e) {
console.log(e);
// 将验证成功后的 token 通过隐藏域传递到后端kg.$("#kgCaptchaToken").value=e["token"];
    },
// 验证失败事务处理failure: function (e) {
console.log(e);
    },
// 点击刷新按钮时触发refresh: function (e) {
console.log(e);
    }
});
// 检查表单提交functioncheck() {
if (kg.$("#kgCaptchaToken").value=="") {
alert("请完成图形验证后提交")
returnfalse;
    } else {
returntrue;
    }
}
</script></head><body><formaction="demo.aspx?cty=1"method="post"id="form"onsubmit="return check();"><!-- 将验证成功后的 token 通过隐藏域传递到后端 --><inputtype="hidden"name="kgCaptchaToken"id="kgCaptchaToken"value=""/><divclass="inputForm"><inputtype="text"name="username"placeholder=" 例:填写登录帐号"/><br/><inputtype="password"name="password"placeholder=" 例:填写登录密码"/></div><!-- 绑定显示区域 --><divid="captchaBox"></div><inputtype="submit"value="提  交"class="btn"/></form></body></html>

  • demo.aspx.cs
usingSystem;
usingKgCaptchaSDK;
publicpartialclass_Default : System.Web.UI.Page{
protectedvoidPage_Load(objectsender, EventArgse) {
// 后端处理stringhtml, appId, appSecret, Token;
if (Request.Form.ToString().Length>0){  // 有数据处理stringcty=Request.QueryString["cty"];
// 设置 AppId 及 AppSecret,在应用管理中获取if (cty=="1"){
appId="appId";
appSecret="appSecret";
            }
// 填写你的 AppId 和 AppSecret,在应用管理中获取varrequest=newkgCaptcha(appId, appSecret);
// 前端验证成功后颁发的 token,有效期为两分钟request.token=Request.Form["kgCaptchaToken"];
// 填写应用服务域名,在应用管理中获取request.appCdn="https://cdn.kgcaptcha.com";
// 当安全策略中的防控等级为3时必须填写,一般情况下可以忽略// 可以填写用户输入的登录帐号(如:$_POST["username"]),可拦截同一帐号多次尝试等行为request.userId="kgCaptchaDemo";
// 请求超时时间,秒request.connectTimeout=5;
// 发送验证请求varrequestResult=request.sendRequest();
if (requestResult.code==0) {
// 验签成功逻辑处理 ***// 这里做验证通过后的数据处理// 如登录/注册场景,这里通常查询数据库、校验密码、进行登录或注册等动作处理// 如短信场景,这里可以开始向用户发送短信等动作处理// ...html="<script>alert('验证通过');history.back();</script>";
            } else {
// 验签失败逻辑处理html="<script>alert(\""+requestResult.msg+" - "+requestResult.code+"\");history.back();</script>";
            }
// 输出结果Response.Write(html);
        } else {
Response.Redirect("index.html");
        }
    }
}


效果展示

5.PNG


最后

SDK开源地址:https://github.com/KgCaptcha,顺便做了一个演示:https://www.kgcaptcha.com/demo

相关实践学习
基于函数计算快速搭建Hexo博客系统
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
相关文章
|
3月前
|
C# Python
C# 笔记1 - 操作目录
C# 笔记1 - 操作目录
30 0
|
3月前
|
C# Python
C# 笔记3 - 重载一系列像python那样的print()方法
C# 笔记3 - 重载一系列像python那样的print()方法
29 1
|
3月前
|
存储 C# C++
C# 笔记2 - 数组、集合与与文本文件处理
C# 笔记2 - 数组、集合与与文本文件处理
46 0
|
10月前
|
存储 网络协议 Java
C# 快速入门笔记
C# 快速入门笔记
C# 快速入门笔记
|
前端开发 C# 数据安全/隐私保护
C#验证码
验证码通常是为了区分用户是人还是计算机,也可以防止破解密码、刷票等恶意行为,而客户端上多数会用在关键操作上,比如购买、登录、注册等场景。现在验证码的种类样式也特别多,今天教大家如何用C#做出滑动拼图验证码吧~
C#验证码
|
SQL 开发框架 算法
【读书笔记】《Effective C#》50条建议笔记整理
对《Effective C#:改善C#代码的50个有效方法》一书整理的读书笔记。
28075 5
【读书笔记】《Effective C#》50条建议笔记整理
|
C# 数据库
C#编程-65:读取数据库DataReader对象复习笔记
C#编程-65:读取数据库DataReader对象复习笔记
C#编程-65:读取数据库DataReader对象复习笔记
|
C# 数据库
C#编程-65:数据库Command对象复习笔记
C#编程-65:数据库Command对象复习笔记
C#编程-65:数据库Command对象复习笔记
|
C# 数据库
C#编程-65:连接数据库复习笔记
C#编程-65:连接数据库复习笔记
C#编程-65:连接数据库复习笔记
C#编程-64:ADO.NET对象模型复习笔记
C#编程-64:ADO.NET对象模型复习笔记
C#编程-64:ADO.NET对象模型复习笔记