随着 B/S 应用系统的兴起,网站登录对安全性的要求也越来越高了,一般情况下都会采用验证码的方式提高网站系统的安全等级。

验证码业务流程

  在实现验证码功能之前,先弄明白验证码的业务流程。

  • 1、当打开登录界面时,前端就会向后端发送一个验证码数据的网络请求,以获取验证码的图片数据及验证码图片的唯一标记;
  • 2、后端接口通过请求,随机产生一个验证码文本字符串,大概为 6 位左右的数字、字母或者汉字等;
  • 3、通过生成的字符串生成验证码图片,这个图片包含验证码文本字符串的内容,同时添加噪点、无规则的线条、扭曲文本内容等,这样的操作目的是在保证真人能够识别的情况下防止机器伪装真人识别二维码图片上的内容而进行攻击;
  • 4、生成好图片后,将图片转成 Base64 的图片数据,同时生成一个唯一标记的 ID,将唯一标记的 ID 与验证码文本内容缓存到后端服务器中或者数据库中;
  • 5、后端向前端响应验证码图片的 Base 数据及唯一标记 ID ,用以用户登录时跟随用户登录信息发送到后端登录接口验证;
  • 6、用户登录时,后端接口首先验证验证码是否过期以及合法性,根据用户登录请求携带的验证码图片的唯一标记 ID 获取缓存在后端的验证码跟用户输入的验证码进行比较,相同即验证码正确,否则不予登录。
    前 端 后 端 向后端发送验证码图片请求 login Page Image Base64 、ID 生成验证码 生成验证码图片 缓存验证码和 ID 用户登录 键入登录信息 User Info 、Verification code、ID 检验验证码

生成验证码

  生成验证码的任务主要是生成一个随机的固定长度的字符串,尽可能保证这个字符串随机即可,下面我将主要利用 Random 类实现生成一个包含数字、大小写字母的验证码。

public static string RandomVerificationCode(int lengths)
{string[] chars = new string[] { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "P", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" };string code = "";Random random = new Random();for (int i = 0; i < lengths; i++){code += chars[random.Next(chars.Length)];}return code;
}

C# 中绘制图像

  C# 中绘制图像,主要用 BitmapGraphics 两个类即可完成。 Bitmap 用于创建一个 BMP 的图像,Graphics 用于在这个图像上绘制噪点、验证码内容等。以下代码详细展示绘制验证码的过程。

public static Bitmap DrawImage(string code)
{Color[] colors = {Color.Red, Color.OrangeRed,Color.SaddleBrown,Color.LimeGreen,Color.Green,Color.MediumAquamarine,Color.Blue,Color.MediumOrchid,Color.Black,Color.DarkBlue,Color.Orange,Color.Brown,Color.DarkCyan,Color.Purple};string[] fonts = { "Verdana", "Microsoft Sans Serif", "Comic Sans MS", "Arial", "宋体" };Random random = new Random();// 创建一个 Bitmap 图片类型对象Bitmap bitmap = new Bitmap(code.Length * 18, 32);// 创建一个图形画笔Graphics graphics = Graphics.FromImage(bitmap);// 将图片背景填充成白色graphics.Clear(Color.White);// 绘制验证码噪点for (int i = 0; i < random.Next(60,80); i++){int pointX = random.Next(bitmap.Width);int pointY = random.Next(bitmap.Height);graphics.DrawLine(new Pen(Color.LightGray,1), pointX, pointY, pointX+1, pointY);}// 绘制随机线条 1 条graphics.DrawLine(new Pen(colors[random.Next(colors.Length)], random.Next(3)),new Point(random.Next(bitmap.Width),random.Next(bitmap.Height)),new Point(random.Next(bitmap.Width),random.Next(bitmap.Height)));// 绘制验证码for (int i = 0; i < code.Length; i++){graphics.DrawString(code.Substring(i, 1),new Font(fonts[random.Next(fonts.Length)], 15, FontStyle.Bold),new SolidBrush(colors[random.Next(colors.Length)]),16 * i + 1,random.Next(0, 5));}// 绘制验证码噪点for (int i = 0; i < random.Next(30, 50); i++){int pointX = random.Next(bitmap.Width);int pointY = random.Next(bitmap.Height);graphics.DrawLine(new Pen(colors[random.Next(colors.Length)], 1), pointX, pointY, pointX, pointY + 1);}// 绘制随机线条 1 条graphics.DrawLine(new Pen(colors[random.Next(colors.Length)], random.Next(3)),new Point(random.Next(bitmap.Width),random.Next(bitmap.Height)),new Point(random.Next(bitmap.Width),random.Next(bitmap.Height)));return bitmap;
}

  以上方法只是将验证码图片生成为 BMP 图片数据,如果是前端展示的话,还需要将图片数据转换成 Base64 的图片数据,代码如下所示。

public static string BitmapToBase64Str(Bitmap bitmap)
{using (MemoryStream memoryStream = new MemoryStream()){bitmap.Save(memoryStream, ImageFormat.Jpeg);byte[] bytes = memoryStream.ToArray();return Convert.ToBase64String(memoryStream.ToArray());}
}

总结

  在这个案例中,验证码的实现难点主要在于对 BitmapGraphics 的使用熟练程度,但在此案例中却使用比较简单,没有特别复杂的内容,如果想要通过代码来实现绘画的话,还是需要有一定的图形想象能力的哦。结合这个案例,我做了一个 WindowsForm 的原码,如文章开头所示,喜欢的朋友可以获取下来,研究学习哦。

GitHub: CaptchaImage GitHub
Gitee: CaptchaImage Gitee

C# 绘制验证码图片相关推荐

  1. python绘制动态模拟图-Python 模拟生成动态产生验证码图片的方法

    模拟动态产生验证码图片 模拟生成验证码,首先要做的是生成随机的字母,然后对字母进行模糊处理.这里介绍一下 Python 提供的 Pillow 模块. Pillow PIL:Python Image L ...

  2. python绘制动态模拟图-Python 模拟动态产生验证码图片

    模拟动态产生验证码图片 模拟生成验证码,首先要做的是生成随机的字母,然后对字母进行模糊处理.这里介绍一下 Python 提供的 Pillow 模块. Pillow PIL:Python Image L ...

  3. python绘制动态模拟图-Python 模拟动态产生字母验证码图片功能

    模拟动态产生字母验证码图片 模拟生成验证码,首先要做的是生成随机的字母,然后对字母进行模糊处理.这里介绍一下 Python 提供的 Pillow 模块. Pillow PIL:Python Image ...

  4. android+canvas+图片,android 开发 View _12_ 用Canvas 绘制一张图片(博客中演示用Canvas画验证码图片)...

    packagenet.yt.yuncare.widgets;importandroid.graphics.Bitmap;importandroid.graphics.Canvas;importandr ...

  5. 图片验证码识别 python web_Python web中实现验证码图片

    在flask中使现验证码 #!/usr/bin/env python3 # -*- coding: utf-8 -*- # @Author : Yang # @Time : 2017/11/08 15 ...

  6. PIL应用之生成验证码图片

    PIL应用之生成验证码图片 - 残阳似血的博客 PIL应用之生成验证码图片 位于分类 我爱Python 现在的网页中,为了防止机器人提交表单,图片验证码是很常见的应对手段之一.这里就不详细介绍了,相信 ...

  7. java实现验证码图片_java实现验证码图片

    1 packagesip.utils;2 importjava.awt.Color;3 importjava.awt.Graphics2D;4 importjava.awt.geom.AffineTr ...

  8. python生成4位验证码_Python 生成4位验证码图片

    import random import string from PIL import Image,ImageDraw,ImageFont,ImageFilter # 字体的位置 font_path ...

  9. struts2生成随机验证码图片

    之前想做一个随机验证码的功能,自己也搜索了一下别人写的代码,然后自己重新用struts2实现了一下,现在将我自己实现代码贴出来!大家有什么意见都可以指出来! 首先是生成随机验证码图片的action: ...

最新文章

  1. CVPR2021(Oral) 商汤、港中文实现单目人脸重建新突破: 基于生成网络的渲染器!几何形状更精准!渲染效果更真实!...
  2. go where 不等于_go基础之map迭代(四)
  3. WINCE5.0+S3C2440支持大容量SD卡(SDHC卡)
  4. Github项目推荐 | OI Wiki:编程竞赛最全知识整合站点
  5. 微信小程序- 初试小程序之tabbar(选项卡,底部导航)的使用
  6. OSPF的LSA类型~
  7. SpringCloud Zuul(十)之配置路由prefix坑
  8. excel实战应用案例100讲(四)-Excel玩转数据:从分析到可视化
  9. leetcode1047. 删除字符串中的所有相邻重复项(栈的日常应用)
  10. 为什么很多人赚不到钱?
  11. 二维 稳态边界层问题MATLAB,第三章 边界层理论.ppt
  12. coverity静态安全扫描分析软件linux环境搭建
  13. 服务器怎么增加路由,给Windows服务器添加永久路由的脚本
  14. xcode证书及打包
  15. 计算机师徒结对方案,指导青年教师(师徒结对)工作计划
  16. node-sassnpm ERR! command failed
  17. mysql 失败 捕获 net core_从NetCore报错到MySql安全
  18. javascript 全栈_什么是JavaScript? 全栈编程语言
  19. 蓝月亮做java好吗,“蓝月亮”蓝吗?历史上真正的蓝月亮,你真就不敢看
  20. android 11.0 wifi密码保存的位置

热门文章

  1. 如何在https协议下访问http等不安全的资源
  2. CDN加速可以为网络用户解决哪些难题?
  3. 上交计算机考研专业课,2018上交考研经验贴
  4. 【计组】主存储器有关知识梳理
  5. 企业为什么要绘制用户画像?谈谈用户画像的真正作用
  6. 权限和归属——基本权限和特殊权限
  7. cache object script基本结构---Cache变量,变量名称,定义,特殊的变量
  8. 纳米数据世界杯数据接口,中超数据,体育数据比分,世界杯赛程api,足球比赛实时数据接口
  9. 一文掌握java对内存空间的划分
  10. 高数笔记(三):函数的连续性和间断性,闭区间上连续函数的性质