前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C#生成图形验证码

C#生成图形验证码

作者头像
喜欢ctrl的cxk
发布2019-11-07 21:28:21
1.5K0
发布2019-11-07 21:28:21
举报
文章被收录于专栏:Don的成长史Don的成长史

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。undefined本文链接:https://blog.csdn.net/weixin_42449444/article/details/90723302

我弄的这个图形验证码是通过伪随机验证码+label控件+背景图来实现的,我觉得我这个图形验证码写得比较low,用代码实现起来也特别简单。

伪随机验证码的生成:

伪随机验证码的生成,其实就是伪随机字符串的生成。这部分我是通过无脑for循环+Random随机选择字符来实现的。

先把验证码中包含的所有元素(大小写字母和数字)放入一个string型的字符串list中,然后调用Random()随机生成一个下标,通过这个下标来获取list中对应的字符,for循环length次后,就能得到一个长度为length的伪随机验证码。是不是很简单很low呀??我直接把这段代码写在了项目的静态类Program中,这样的话,所有窗体都可以通过调用静态方法Program.CreateRandomCode(length)来生成一个包含大小写字母和数字的、长度位length的伪随机验证码。

代码语言:javascript
复制
public static string CreateRandomCode(int length)  //生成由数字和大小写字母组成的验证码
{
    string list = "qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890";  
    //list中存放着验证码的元素
    Random random = new Random();
    string code = "";   //验证码
    for (int i = 0; i < length; i++)   //循环6次得到一个伪随机的六位数验证码
    {
        code += list[random.Next(0, list.Length - 1)];
    }
    return code;
}

label控件的设置:

我们可以在窗体中添加一个lable,然后调用CreateRandomCode(length)来进行实例化,代码如下。

代码语言:javascript
复制
lable.Text = CreateRandomCode(4);   //生成一个4位的验证码,并显示在标签lable上。

然而这样的验证码是没有灵魂,我们可以给label设置一个好看点的背景图,让这个low到爆炸的验证码看起来高大上一点。

对lable进行右键选中属性,然后在Image属性这一栏添加一张图片来作为label的背景,这样看起来效果是不是好一点啦?

点击更换验证码的实现:

要是看不清图形验证码怎么点击更换呢?我们可以在窗体中双击lable对它添加一个Click事件,当鼠标点击label时,调用静态类Program中的静态方法CreateRandomCode(length)来生成一个新的图形验证码,从而实现"看不清,点击更换验证码"的操作。

代码语言:javascript
复制
private void lable_Click(object sender, EventArgs e)
{
    lable.Text = Program.CreateRandomCode(4);
}

当然,我们还可以在label旁边添加一个linklabel(linklabel.Text为"看不清?点击更换"),然后对linklabel添加Click事件即可。LinkBehavior属性我设置成了HoverUnderline,只有当鼠标放在linklabel上才会有下划线。

代码语言:javascript
复制
private void LinkLabel3_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
    lable_Click(sender, e);
}

验证码正误判断:

验证码的判断是忽略字母大小写的,这里我把文本框textBox中输入的内容和验证码都转换成小写字母再进行比对。

代码语言:javascript
复制
if (textBox.Text.ToLower() != lable.Text.ToLower())   //验证码输入错误
{
    MessageBox.Show("您输入的验证码有误!", "警告", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
    CheckCode_Click(sender,e);   //刷新一遍验证码
    textBox.Text = "";    //清空验证码输入框
}
else   //验证成功
{
    MessageBox.Show("验证成功!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information);
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-05-31 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 伪随机验证码的生成:
  • label控件的设置:
  • 点击更换验证码的实现:
  • 验证码正误判断:
相关产品与服务
验证码
腾讯云新一代行为验证码(Captcha),基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证。最大程度保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下业务安全的同时,提供更精细化的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档