搜索

查看: 3041|回复: 11

[ASP.NET] .NET 6实现滑动验证码的示例详解

[复制链接]
发表于 2023-5-4 11:26:06 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:26:06 3041 11 看全部
目录
  • CaptchaData.cs
  • CaptchaValidateData.cs
  • ImageCaptchaInfo.cs
  • Resource.cs
  • SliderImageCaptchaInfo.cs
  • SlideTrack.cs
  • TemplatePair.cs
  • Track.cs本节创建的类全部在工程的Model目录下:

    CaptchaData.cs
    CaptchaData.cs:验证码的数据类实体
    namespace SlideCaptcha.Model
    {
        public class CaptchaData
        {
            ///
            /// id
            ///
            public string Id { get; set; }
            ///
            /// 背景图(含凹槽)
            ///
            public string BackgroundImage { get; set; }
            ///
            /// 滑动块图
            ///
            public string SliderImage { get; set; }
            public CaptchaData(string id, string backgroundImage, string sliderImage)
            {
                Id = id;
                BackgroundImage = backgroundImage;
                SliderImage = sliderImage;
            }
        }
    }
    id表示验证码的id值,用于校验验证码,BackgroundImage 是验证码图片base64,包含了凹槽。凹槽模板在templates目录下。SliderImage 是滑块图片。模板在templates下。

    CaptchaValidateData.cs
    CaptchaValidateData.cs:验证码验证数据实体
    namespace SlideCaptcha.Model
    {
        public class CaptchaValidateData
        {
            ///
            /// 滑动比例
            ///
            public float Percent { get; set; }
            ///
            /// 容错值(校验时用,缺口位置与实际滑动位置匹配容错范围)
            ///
            public float Tolerant { get; set; }
            public CaptchaValidateData(float percent, float tolerant)
            {
                Percent = percent;
                Tolerant = tolerant;
            }
        }
    }
    ImageCaptchaInfo.cs
    ImageCaptchaInfo.cs:证码图片信息实体
    namespace SlideCaptcha.Model
    {
        public class ImageCaptchaInfo
        {
            ///
            /// 背景图宽
            ///
            public int BackgroundImageWidth { get; set; }
            ///
            /// 背景图高
            ///
            public int BackgroundImageHeight { get; set; }
            ///
            /// 背景图
            ///
            public string BackgroundImageBase64 { get; set; }
            ///
            /// 滑动块图宽
            ///
            public int SliderImageWidth { get; set; }
            ///
            /// 滑动块图高
            ///
            public int SliderImageHeight { get; set; }
            ///
            /// 滑动块图
            ///
            public string SliderImageBase64 { get; set; }
        }
    }
    验证码实体类的基类,滑动验证码、旋转验证码、点选验证码、拼接验证码都基于这个类。

    Resource.cs
    Resource.cs :资源实体类
    namespace SlideCaptcha.Model
    {
        public class Resource
        {
            public Resource(){}
            ///
            /// 资源数据
            ///
            public string Data { get; set; }
            ///
            /// 资源类型
            ///
            public string Type { get; set; }
            
            ///
            /// 构造函数
            ///
            /// 资源类型
            /// 资源数据
            public Resource(string type,string data)
            {
                Type = type;
                Data = data;
            }
        }
    }
    资源数据,Data为要生成验证码图片路径。Type为类型,目前仅为本地文件,后期将扩展URL模式。

    SliderImageCaptchaInfo.cs
    SliderImageCaptchaInfo.cs:滑动验证码实体类
    using SlideCaptcha.Exceptions;
    namespace SlideCaptcha.Model
    {
        public class SliderImageCaptchaInfo : ImageCaptchaInfo
        {
            ///
            /// 凹槽x坐标
            ///
            public int X { get; set; }
            ///
            /// 凹槽y坐标
            ///
            public int Y { get; set; }
            ///
            /// 凹槽位置百分比
            ///
            public float Percent
            {
                get
                {
                    if (BackgroundImageWidth
    SlideTrack.cs
    ·SlideTrack.cs:滑动轨迹·
    using SlideCaptcha.Exceptions;
    using System;
    using System.Collections.Generic;
    namespace SlideCaptcha.Model
    {
        ///
        /// 滑动轨迹
        ///
        public class SlideTrack
        {
            ///
            /// 背景图片宽度(可能经过缩放,不是原始图片宽高)
            ///
            public int BackgroundImageWidth { get; set; }
            ///
            /// 背景图片高度(可能经过缩放,不是原始图片宽高)
            ///
            public int BackgroundImageHeight { get; set; }
            ///
            /// 滑块图片宽度(可能经过缩放,不是原始图片宽高)
            ///
            public int SliderImageWidth { get; set; }
            ///
            /// 滑块图片高度(可能经过缩放,不是原始图片宽高)
            ///
            public int SliderImageHeight { get; set; }
            ///
            /// 滑动开始时间(可能经过缩放,不是原始图片宽高)
            ///
            public DateTime StartTime { get; set; }
            ///
            /// 滑动结束时间
            ///
            public DateTime EndTime { get; set; }
            ///
            /// 轨迹
            ///
            public List[Tr] Tracks { get; set; }
            ///
            /// 滑动比例
            ///
            public float Percent
            {
                get
                {
                    if (this.BackgroundImageWidth
    TemplatePair.cs
    ·TemplatePair.cs:模板类·

    namespace SlideCaptcha.Model
    {
        public class TemplatePair
        {
            public TemplatePair() { }
            ///
            /// 滑块资源
            ///
            public Resource Slider { get; set; }
            ///
            /// 凹槽资源
            ///
            public Resource Notch { get; set; }
            ///
            /// 模板类型
            ///
            public string TYPE { get; set; }
            ///
            /// 构造函数
            ///
            /// 滑块资源
            /// 凹槽资源
            /// 末班类型
            public TemplatePair(Resource slider, Resource notch,string type)
            {
                Slider = slider;
                Notch = notch;
                TYPE = type;
            }
            ///
            /// 创建模板
            ///
            /// 滑块资源
            /// 凹槽资源
            ///
            public static TemplatePair Create(Resource slider, Resource notch,string type)
            {
                return new TemplatePair(slider, notch,type);
            }
            
        }
    }
    Track.cs
    Track.cs :滑动数据实体类
    namespace SlideCaptcha.Model
    {
        public class Track
        {
            ///
            /// X轴
            ///
            public int X { get; set; }
            ///
            /// Y轴
            ///
            public int Y { get; set; }
            ///
            /// 时间
            ///
            public int T { get; set; }
        }
    }
    代码中SlideCaptchaException是自定义错误类。自定义错误类在Extensions文件夹下,这个后面的代码会进行说明。
    下载地址:https://pan.baidu.com/s/1YNlcO0llzO1041XqE4IYNg 提取码:2vf5
    到此这篇关于.NET 6实现滑动验证码的示例详解的文章就介绍到这了,更多相关.NET滑动验证码内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
  • 回复

    使用道具 举报

    发表于 2023-6-29 08:34:30 | 显示全部楼层
    贺老师 2023-6-29 08:34:30 看全部
    楼主太厉害了!楼主,I*老*虎*U!我觉得知鸟论坛真是个好地方!
    回复

    使用道具 举报

    发表于 2023-6-29 09:20:33 | 显示全部楼层
    贰十岁装成熟装s 2023-6-29 09:20:33 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-29 19:03:45 | 显示全部楼层
    井底燕雀傥 2023-6-29 19:03:45 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    回复

    使用道具 举报

    发表于 2023-6-29 20:56:17 | 显示全部楼层
    123456809 2023-6-29 20:56:17 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-29 21:44:50 | 显示全部楼层
    123456848 2023-6-29 21:44:50 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-29 23:21:00 | 显示全部楼层
    啤酒瓶空了缓 2023-6-29 23:21:00 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-30 03:42:23 | 显示全部楼层
    墙和鸡蛋 2023-6-30 03:42:23 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    回复

    使用道具 举报

    发表于 2023-6-30 09:19:19 | 显示全部楼层
    老橡树1 2023-6-30 09:19:19 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-30 21:22:52 | 显示全部楼层
    123456819 2023-6-30 21:22:52 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 知鸟论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表