验证码的生成

开发工具与关键技术:vs mvc
作者:朱某人
撰写时间:2019年5月 23日

说到验证码,大家都不会陌生的了,在登录一些应用或网站时都会出现,在这里给大家说下常见到的验证码,验证码一般由数字和字母组成,还伴随着一些干扰线,不过这不是数字字母,这是一张验证码图片。
要生成验证码,首先是有数字和字母的随机组合,还要区分大小写这些,把随机生成字符串和根据随机字符串生成验证码图片这些代码方法封装好在类里,用到时就调用就行了。//生成随机数(某部分来自网络)
public static string RandomCode(int intLength) { /产生数字和密码混合的随机数/
string strturn = string.Empty;
Random random = new Random();//随机数
for (int i = 0; i < intLength; i++){
char cReru;
int intdom = random.Next();//产生一个非负随机整数
/根据当前随机数来确定字符串/
if (intdom % 3 == 0) {
//位数来产生数字
cReru = (char)(0x30 + (intdom % 10)); }
else if (intdom % 3 == 1) {
//位数产生大写字母:大写字符 65-97 A 65
cReru = (char)(0x41 + (intdom % 0x1a)); }
else{
cReru = (char)(0x61 + (intdom % 0x1a)); }
strturn += cReru.ToString();}
return strturn; }
//根据字符串生成验证码
public static byte[] CreateImage(string strRandom) {
//新增图片
Bitmap newBitmap = new Bitmap(strRandom.Length * 20, 38);
Graphics g = Graphics.FromImage(newBitmap);
g.Clear(Color.White);
//在图片上绘制文字
SolidBrush solidBrush = new SolidBrush(Color.Red);
g.DrawString(strRandom, new Font(“Aril”, 18), solidBrush, 12, 4);
//在图片上绘制干扰线
Random random = new Random();
for (int i = 0; i < 10; i++)
{
//产生一条线,并绘制到画布。 起始点(x,y) 总结点
int x1 = random.Next(newBitmap.Width);
int y1 = random.Next(newBitmap.Height);
int x2 = random.Next(newBitmap.Width);
int y2 = random.Next(newBitmap.Height);
g.DrawLine(new Pen(Color.DarkGray), x1, y1, x2, y2);
}
//绘制图片的前景干扰点
for (int i = 0; i < 100; i++){
int x = random.Next(newBitmap.Width);
int y = random.Next(newBitmap.Height);
newBitmap.SetPixel(x, y, Color.FromArgb(random.Next()));}
//在最外边绘制边框
g.DrawRectangle(new Pen(Color.Blue), 0, 0, newBitmap.Width, newBitmap.Height);
g.DrawRectangle(new Pen(Color.Blue), -1, -1, newBitmap.Width, newBitmap.Height);
//将图转保存到内存流中
MemoryStream ms = new MemoryStream();
newBitmap.Save(ms, ImageFormat.Jpeg);
return ms.ToArray();}//将流内容写入byte数组返回
在控制器调用的代码:
public ActionResult CreateValidCodeImag()
{ string strRandom = ValidCodeUtils.GetRandomCode(5);
byte[] imgByte = ValidCodeUtils.CreateImage(strRandom);
Session[“validCode”] = strRandom;
return File(imgByte, @“image/jpeg”);}
这里可以分成五个部分,第一是建立方法并命名,第二步是生成一个字符串,这个随机字符串代表验证码的长度为5位数,第三步是根据生成的随机字符串生成验证码图片,第四步是将验证码字符串存入session中去,最后的是将图片返回到视图中去。
来到视图就在验证码输入框的后面给验证码的图片,

在src的后面写上验证码方法所在的路径就好了,在设置宽高。就会在页面上显示出验证码了。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20190527214758953.PNG) 这样就完成了验证码的生成了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值