实现:随机生成四位数字的验证码,点击验证码可无刷新生成新的验证码,最后点击按钮进行检验

PS:本实例使用UpdatePanel实现无刷新。

前台代码:

<asp:ScriptManager ID="ScriptManager1" runat="server" ></asp:ScriptManager>
页面加载时间:<asp:Label ID="Label1" runat="server" Text=""></asp:Label>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<div>
请输入验证码:<asp:TextBox ID="TextBox1" runat="server" Width="50px"></asp:TextBox>
<asp:ImageButton ID="btnImage" runat="server" ImageAlign="AbsMiddle" OnClick="btnImage_Click" />
<asp:Label ID="Label2" runat="server" Text=""></asp:Label>
<asp:HiddenField ID="hidImgVal" runat="server" />
</div>
<div>
<input type="button" value="检验" onclick="document.getElementById('hidImgVal').value == document.getElementById('TextBox1').value ? alert('验证通过') : alert('验证码不正确');" />
</div>
</ContentTemplate>
<Triggers><asp:AsyncPostBackTrigger ControlID="btnImage" EventName="Click"></asp:AsyncPostBackTrigger></Triggers>
</asp:UpdatePanel>

后台代码:

protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
CreateCheckCodeImage(, );
this.Label1.Text = DateTime.Now.ToString();
}
} //生成四位随机字符
private string CreateCheckCodeString()
{
char[] allCharArray =
{
'','','','','','','','','',''
}; string randomCode = "";
Random rd = new Random();
for (int i = ; i < ; i++)
{
randomCode += allCharArray[rd.Next(allCharArray.Length)];
} return randomCode;
} public void CreateCheckCodeImage(int iWidth, int iHeight)
{ Random rand = new Random();
Bitmap image = new Bitmap(iWidth, iHeight);//创建一个指定宽高的位图
Graphics g = Graphics.FromImage(image);//将位图放入画图板
g.Clear(ColorTranslator.FromHtml("#F0F0F0"));//清除画图板底色并填充新的颜色 //随机2条横向干扰线
for (int i = ; i < ; i++)
{
Pen pen1 = new Pen(Color.FromArgb(, rand.Next(), rand.Next(), rand.Next()), );//干扰线1
Point p1 = new Point(, rand.Next(iHeight));//横线起点
Point p2 = new Point(iWidth, rand.Next(iHeight));//横线终点
g.DrawLine(pen1, p1, p2);
} //随机4条纵向干扰线
for (int i = ; i < ; i++)
{
Pen pen2 = new Pen(Color.FromArgb(, rand.Next(), rand.Next(), rand.Next()), );//干扰线2
Point p1 = new Point(rand.Next(iWidth), );//横线起点
Point p2 = new Point(rand.Next(iWidth), iHeight);//横线终点
g.DrawLine(pen2, p1, p2);
} //随机字符转为图片
Font font = new Font("华文彩云", , FontStyle.Bold);//字体
SolidBrush brush = new SolidBrush(Color.Red);//颜色
Rectangle rect = new Rectangle(, , iWidth, iHeight);//文字区域
string code = CreateCheckCodeString();
this.hidImgVal.Value = code;
g.DrawString(code, font, brush, rect); //保存验证图
string path = HttpContext.Current.Server.MapPath(".");
string imgName = "img" + code + ".jpg";
image.Save(path + @"\img\4_5\" + imgName, ImageFormat.Jpeg);
this.btnImage.ImageUrl = "~/img/4_5/" + imgName; //释放对象
g.Dispose();
image.Dispose();
} protected void btnImage_Click(object sender, ImageClickEventArgs e)
{
//删除文件
string path = HttpContext.Current.Server.MapPath(".");
string imgName = "img" + this.hidImgVal.Value + ".jpg";
if (File.Exists(path + @"\img\4_5\" + imgName))
{
File.Delete(path + @"\img\4_5\" + imgName);
} CreateCheckCodeImage(, );
this.Label2.Text = DateTime.Now.ToString();
}

遗留问题:

虽然功能实现,但图片保存使用了动态路径,原因是静态路径无法实现刷新,所以会有日益增加的验证图文件。

但是想想,如果可以使用静态路径,那么100个用户同时读取该验证图会有什么结果?

看来较好的方式是将缩略图存放在客户端:)

网上有一种使用MemoryStream来存放验证图:

System.IO.MemoryStream ms = new System.IO.MemoryStream();
image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
Response.ClearContent();
Response.ContentType = "image/Jpeg";
Response.BinaryWrite(ms.ToArray());

但不知道怎么传给图片的路径,这里请大师指点。

ASP.NET——生成验证码的更多相关文章

  1. 012. asp.net生成验证码图片(汉字示例/字母+数字)

    protected void Page_Load(object sender, EventArgs e) { //生成验证码图片的基本步骤 string checkCode = "新年快乐& ...

  2. Asp.net 生成验证码

    生成验证码一般来说大体有这么几步: 1.生成验证码字符串,一般由四个或更多随机字符拼凑而成: 2.填充图片背景,并绘制图片的背景噪音线: 3.将验证码绘制到图片中: 4.绘制前景噪点: 5.返回图片流 ...

  3. 【转载】ASP.NET 生成验证码

    直接上code using System; using System.Collections.Generic; using System.Linq; using System.Web; using S ...

  4. ASP.NET生成验证码

    首先,添加一个一般处理程序 注释很详细了,有不懂的欢迎评论 using System; using System.Collections.Generic; using System.Drawing; ...

  5. ASP.NET图形验证码的生成

    效果: 调用方法: int[] r = QAPI.VerifImage.RandomList();//取得随机数种子列 );//产生验证码字符 pictureBox1.Image = QAPI.Ver ...

  6. ASP.NET ashx实现无刷新页面生成验证码

    现在大部分网站登陆时都会要求输入验证码,在网上也看了一些范例,现在总结一下如何实现无刷新页面生成验证码. 效果图: 实现方式: 前台: <div> <span>Identify ...

  7. 详细说说如何生成验证码—ASP.NET细枝末节(4)

    前言 今天小编详细的说一下,ASP.NET网站开发过程中生成验证码的全部问题. 本文的目标,是让读者了解,生成验证码涉及的全部基础知识问题. 当然这里说的是比较简单的验证码. 真正符合要求的验证码,涉 ...

  8. (一)【转】asp.net mvc生成验证码

    网站添加验证码,主要为防止机器人程序批量注册,或对特定的注册用户用特定程序暴力破解方式,以进行不断的登录.灌水等危害网站的操作.验证码被广泛应用在注册.登录.留言等提交信息到服务器端处理的页面中.   ...

  9. Asp.net mvc生成验证码

    1.生成验证码类 using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...

随机推荐

  1. android stutio 快捷键

    [F] [F] F2 在错误代码之间切换 F3 往前定位(Shift + F3:往后定位 )有问题 F4\Ctrl+鼠标点击\Ctrl+B 转到定义,查看类继承关系 F5 但不调试进入函数内部. F6 ...

  2. redis windows下的环境搭建

    先说下安装吧!感觉这东西跟mongodb差不多,安装和布置挺简单,下载地址:https://github.com/dmajkic/redis/downloads 下载下来的包里有两个,一个是32位的, ...

  3. 如何生成DLL文件

    1.打开项目工程,点击Rebuild 2.Rebuild成功后,打开该项目所在文件目录 3.在路径里,在bin->Debug文件下可以看到刚生成成功的dll文件.

  4. 浅谈 PHP 与手机 APP 开发(API 接口开发)

    本文内容转载自:http://www.thinkphp.cn/topic/5023.html 这个帖子写给不太了解PHP与API开发的人一.先简单回答两个问题:1.PHP 可以开发客户端?答:不可以, ...

  5. CentOS install GCC-4.8.5

    1. 下载源码:http://ftp.gnu.org/gnu/gcc 2. cd gcc-4.8.5 ./contrib/download_prerequisites       //下载资源包 3. ...

  6. GMF:如何在不打开Editor的情况下生成图片

    问题 GMF应用中,有时我们希望在不打开*DiagramEditor的情况下,从文件就能生成它的图片   解决方案 首先,从文件中构造DiagramImpl实例: TransactionalEditi ...

  7. RCP:如何把Preferences中的项从一个类别移动到另一个类别

    前言 很久没写文章了,准备写一系列关于Eclipse RCP /Plugin的文章. 这些文章都是trouble shooting性质的,不准备写的很细,当你碰到这样的问题,google到时,能帮你把 ...

  8. zabbix通过API创建交换机模板,ifAdminStatus;ifOperStatus;ifInUcastPkts;ifAlias

    最终效果: 目的:         通过zabbix的Latest data查看主机就可以看到其监控结果. 监控项:         # 管理状态          IF-MIB::ifAdminSt ...

  9. [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序更新相关数据

    这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第八篇:为ASP.NET MVC应用程序 ...

  10. oracle数据库的TNS配置

    TNS简要介绍与应用 Oracle中TNS的完整定义:transparence Network Substrate透明网络底层,监听服务是它重要的一部分,不是全部,不要把TNS当作只是监听器. TNS ...