C#生成图形验证码

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接: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的伪随机验证码。

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)来进行实例化,代码如下。

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

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

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

点击更换验证码的实现:

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

private void lable_Click(object sender, EventArgs e)
{
    lable.Text = Program.CreateRandomCode(4);
}

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

private void LinkLabel3_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
    lable_Click(sender, e);
}

验证码正误判断:

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

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);
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券