`
snake_hand
  • 浏览: 624817 次
社区版块
存档分类
最新评论

ASP.NET生成随机验证码代码和看不清切换验证码的小结

 
阅读更多

经过亲自测试,本代码复制并按照说明,可以直接运行

============================================================

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Drawing;
using System.IO;

public partial class CheckCode : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
this.CreateCheckCodeImage(GenerateCheckCode());
}

/// <summary>
/// 创建随机生成的验证码,可以为数字或字母
/// </summary>
/// <returns></returns>

private string GenerateCheckCode()
{
int number = 0;
char code;
string checkcode = string.Empty;

// 随机生成数字,并转换成5个数字或字母
System.Random random = new Random();
for (int i = 0; i < 5; i++)
{
number = random.Next();
if (number % 2 == 0)
code = (char)('0' + (char)(number % 10)); // 数字
else
code = (char)('A' + (char)(number % 26)); // 字母

checkcode += code.ToString();
}
Response.Cookies.Add(new HttpCookie("CheckCode", checkcode));
return checkcode;
}

/// <summary>
/// 创建随机验证的图片,包括背景色和前景色
/// </summary>
/// <param name="checkcode"></param>
private void CreateCheckCodeImage(string checkcode)
{
if (checkcode == null || checkcode.Trim() == string.Empty)
return;

Bitmap image = new Bitmap((int)Math.Ceiling((checkcode.Length * 12.8)), 24);
Graphics grp = Graphics.FromImage(image);

try
{
// 产生随机生成码
Random random = new Random();

// 清空图片背景色
grp.Clear(Color.White);

// 画图片的背景噪音线
for (int i = 0; i < 25; i++)
{
int x1 = random.Next(image.Width);
int x2 = random.Next(image.Width);
int y1 = random.Next(image.Height);
int y2 = random.Next(image.Height);

grp.DrawLine(new Pen(Color.SpringGreen), x1, x2, y1, y2);
}
Font font = new Font("Arial", 12, (FontStyle.Bold | FontStyle.Italic));
System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.DarkRed, 1.2f, true);
grp.DrawString(checkcode, font, brush, 2, 2);

// 画图片的前景噪音点
for (int i = 0; i < 100; i++)
{
int x = random.Next(image.Width);
int y = random.Next(image.Height);

image.SetPixel(x, y, Color.FromArgb(random.Next()));
}

// 画图片的边框线
grp.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);

MemoryStream ms = new MemoryStream();
image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
Response.ClearContent();
Response.ContentType = "image/Gif";
Response.BinaryWrite(ms.ToArray());
}
catch (System.Exception ex)
{
Response.Write(ex.Message);
}
finally
{
// 清除类对象(Graphics和Bitmap)
grp.Dispose();
image.Dispose();
grp = null;
image = null;
}
}
}

生成随机验证码的配置说明:

假如以上验证码生成器页面名为:CheckCode.aspx,那么在登录页面中使用“<IMG>” 这个 HTML 元素来显示生成的验证码图片:<IMG src="CheckCode.aspx">
  在登录页面的登录按钮的处理事件中使用以下代码判断验证码:

private void btnLogin_Click(object sender, System.Web.UI.ImageClickEventArgs e)
{
if(Request.Cookies["CheckCode"] == null)
{
lblMessage.Text = "您的浏览器设置已被禁用 Cookies,您必须设置浏览器允许使用 Cookies 选项后才能使用本系统。";
lblMessage.Visible = true;
return;
}

if(String.Compare(Request.Cookies["CheckCode"].Value, txtCheckCode.Text, true) != 0)
{
lblMessage.Text = "验证码错误,请输入正确的验证码。";
lblMessage.Visible = true;
return;
}

添加图片,便切换验证码设置:

<img src="CheckCode.aspx" alt="若看不清,点击更换一张!!" onclick="this.src=this.src+'?'" />

转载声明: 本文转自http://wyzhjmy.blog.163.com/blog/static/7234753520093353751852/

=====================================================================

另外,亦可参考:

无刷新更换验证码

现在越来越多的网站的注册、发布等页面都采用了防止一些恶意程序的图片验证码选项,不知道大家有没有碰到这样的情况,一个注册表单,填写了帐号信息、个人信息,最后一项的验证码太模糊了竟然看不清,只能是重新刷新整个页面来刷新图片验证码的内容,这是一个不良好的交互设计。参考了一些门户网站的方法,我的改进设计思路如下:

把验证码输入项放在表单的第一行;客户端可以在不刷新整个页面的情况下更新图片验证码的内容。

我们一般要插入验证码都是使用<img />标签,例如<img src="validate.aspx" />,其中validate.aspx是一个生成图片的程序文件。为了能够更新验证码的内容,可以在图片旁边加一个更新的链接,单击触发图片重载事件,完成图片验证码的更换。具体代码如下:

<a href="javascript:reloadcode();" title="更换一张验证码图片"><img src="validate.aspx" id="safecode" alt="看不清,请换一张" /></a> <a href="javascript:reloadcode();" title="更换一张验证码图片">看不清,请换一张</a>

<script language="JavaScript">
function reloadcode()
{
document.getElementById('safecode').src = 'validate.aspx?' + Math.random();
}
</script>


注意:在reloadcode函数中,我们在code.asp后面加了一个随机参数,这样每次的链接地址都不一样,从而达到更新的目的。

<img src="validate.aspx"id="safecode" border="0" style="cursor:pointer;" onClick="this.src='validate.aspx?t='+Math.random()" alt="点击更换验证码">

===============================================================================

无刷新更换验证码

<script language ="javascript" type ="text/javascript">
function reloadcode()
{
document.getElementById('safecode').src = 'test.aspx?' + Math.random();
}
script>
<a href="javascript:reloadcode();" title="更换一张验证码图片">
<IMG src="test.aspx" id="safecode" alt="看不清,点击换张验证码">a>
在reloadcode函数中,我们在code.asp后面加了一个随机参数,这样每次的链接地址都不一样,从而达到更新的目的。

---------------------------------------------------------------------------------------

<img src="manage_product_checkCode.aspx" id="safecode" alt="看不清,点击换张验证码"/>
<a href="javascript:reloadcode()" title="更换一张验证码图片">更换一张验证码图片
</a>

---------------------------------------------------------------------------------------

转载声明: 本文转自http://czm600604604.blog.163.com/blog/static/8252068200981091443438/

无刷新更换验证码

页面中代码

<script language="javascript">
function change()
{
var img =document.getElementById("Image1");
img.src=img.src+'?';
}
</script>

<img id="Image1" src="Image.aspx"/><a href="javascript:change();">看不清,换一张</a>

=====================================================================

图形验证码+“看不清楚换一张”

Image.aspx.cs 中代码

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Drawing;
using System.Drawing.Text;
using System.Drawing.Drawing2D;
using System.Drawing.Imaging;
using System.Drawing.Design;


//生成随机字符串
public partial class Image : System.Web.UI.Page
{
private string CreateRandomNum(int NumCount)
{
string allChar = "0,1,2,3,4,5,6,7,8,9";
string[] allCharArray = allChar.Split(',');
string randomNum = "";
int temp = +1;
Random rand = new Random();
for (int i = 0; i < NumCount; i++)
{
if (temp != -1)
{
rand = new Random(temp * ((int)DateTime.Now.Ticks));
}
int t = rand.Next(10);
if (temp == t)
{
return CreateRandomNum(NumCount);
}
temp = t;
randomNum += allCharArray[t];
}
return randomNum;
}
//生成图片
private void CreateImage(string validateNum)
{
if (validateNum == null || validateNum.Trim() == String.Empty)
return;
System.Drawing.Bitmap image = new System.Drawing.Bitmap(validateNum.Length * 12 + 10, 22);
Graphics g = Graphics.FromImage(image);
try
{
Random random = new Random();
g.Clear(Color.White);
for (int i = 0; i < 25; i++)
{
int x1 = random.Next(image.Width);
int x2 = random.Next(image.Width);
int y1 = random.Next(image.Height);
int y2 = random.Next(image.Height);
g.DrawLine(new Pen(Color.Silver), x1, x2, y1, y2);
}
Font font = new System.Drawing.Font("Arial", 12, (System.Drawing.FontStyle.Bold));
System.Drawing.Drawing2D.LinearGradientBrush brush = new System.Drawing.Drawing2D.LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.DarkRed, 1.2f, true);
g.DrawString(validateNum, font, brush, 2, 2);
for (int i = 0; i < 100; i++)
{
int x = random.Next(image.Width);
int y = random.Next(image.Height);
image.SetPixel(x, y, Color.FromArgb(random.Next()));
}
g.DrawRectangle(new Pen(Color.Silver), 0, 0, image.Width - 1, image.Height - 1);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
image.Save(ms, System.Drawing.Imaging.ImageFormat.Gif);
Response.ClearContent();
Response.ContentType = "image/Gif";
Response.BinaryWrite(ms.ToArray());
}
finally
{
g.Dispose();
image.Dispose();
}
}
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string validateNum = CreateRandomNum(4);
CreateImage(validateNum);
Session["ValidateNum"] = validateNum;
}
}
}


页面中代码

<script language="javascript">
function change()
{
var img =document.getElementById("Image1");
img.src=img.src+'?';
}
</script>

<img id="Image1" src="Image.aspx"/><a href="javascript:change();">看不清,换一张</a>

转载声明: 本文转自http://zzpdownload.blog.163.com/blog/static/83231134200912643320729/

=====================================================================

Javascript 验证码(尚未验证)

需要用到验证码,突然想能否用js做验证码呢?
当然js不能作图,但是可以用js模拟做验证码的
于是花了20分钟按照我的想法尝试做,最后做出来比我想象中的效果还要好,呵呵
先贴个图看看代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>无标题页</title>
    <style type="text/css">

        .code
        {
            background-image:url(code.jpg);
            font-family:Arial;
            font-style:italic;
            color:Red;
            border:0;
            padding:2px 3px;
            letter-spacing:3px;
            font-weight:bolder;
        }
        .unchanged
        {
            border:0;
        }
    
</style>
    <script language="javascript" type="text/javascript">
var code ; //在全局 定义验证码
     function createCode()
     { 
       code = "";
       var codeLength = 6;//验证码的长度
       var checkCode = document.getElementById("checkCode");
       var selectChar = new Array(0,1,2,3,4,5,6,7,8,9,'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z');//所有候选组成验证码的字符,当然也可以用中文的
        
       for(var i=0;i<codeLength;i++)
       {
      
        
       var charIndex = Math.floor(Math.random()*36);
       code +=selectChar[charIndex];
       
       
       }
//       alert(code);
       if(checkCode)
       {
         checkCode.className="code";
         checkCode.value = code;
       }
       
     }
     
      function validate ()
     {
       var inputCode = document.getElementById("input1").value;
       if(inputCode.length <=0)
       {
           alert("请输入验证码!");
       }
       else if(inputCode != code )
       {
          alert("验证码输入错误!");
          createCode();//刷新验证码
       }
       else
       {
         alert("^-^ OK");
       }
       
       }
</script>
</head>
<body>
<form  action="#">
    <input  type="text"  onclick="createCode()" id="input1" />
    
    <input type="text"  id="checkCode" class="unchanged" style="width: 80px"  /><br />
    <input id="Button1"  onclick="validate();" type="button" value="确定" />
</form>
</body>
</html>

转载声明: 本文转自http://www.chenjiliang.com/Article/View.aspx?ArticleID=5449

=====================================================================

分享到:
评论

相关推荐

    用asp.net生成随机验证码

    在ASP.NET中生成随机验证码是一项常见的安全实践,用于防止自动化的机器人或恶意脚本进行非法操作,例如防止垃圾邮件注册、防止重复提交等。验证码通常是一串随机的字符或者数字,用户需要正确输入才能完成相应的...

    asp.net生成随机验证码控件

    通过阅读和理解这些源代码,你可以更好地了解ASP.NET中生成随机验证码的具体实现细节,并且可以根据需求进行定制和优化。 总结来说,生成随机验证码是ASP.NET开发中的一项实用技能,涉及了字符串生成、图像处理、...

    asp.net 生成随机验证码

    在ASP.NET中,生成随机验证码是一项...总之,生成随机验证码是ASP.NET开发中的一个重要环节,涉及到字符串随机生成、图形处理和用户交互等多个方面。通过掌握这些技术,我们可以为Web应用程序提供更强大的安全保障。

    ASP.NET生成随机验证码代码.rar

    在"ASP.NET生成随机验证码代码"这个压缩包中,可能包含了实现以上步骤的C#源代码文件,例如一个名为`GenerateCAPTCHA.aspx.cs`的后台代码文件,以及对应的`.aspx`页面文件,用于展示和处理用户请求。通过查看和学习...

    .net 生成验证码 代码 页面

    首先,我们需要两个关键文件:一个ASP.NET网页(通常是.aspx文件)用于显示和生成验证码,以及一个后端处理代码(如.aspx.cs或.aspx.vb文件)用于生成随机字符串和图像。这两个文件将包含以下功能: 1. **生成随机...

    用ASP.NET生成随机验证码(源码+注释)

    在这个主题中,我们将深入探讨如何使用ASP.NET和C#语言生成随机验证码。 1. **验证码的基本原理**: 验证码(CAPTCHA)全称是“全自动区分计算机和人类的图灵测试”(Completely Automated Public Turing test to ...

    ASP.NET生成图片验证码

    ### ASP.NET生成图片验证码知识点详解 #### 一、概述 在Web应用开发中,验证码是一种常见的安全措施,用于区分操作者是人还是自动化程序。本文将详细介绍如何在ASP.NET环境中生成图片验证码,包括代码实现与关键...

    Asp.Net 生成验证码

    总结,Asp.Net生成验证码涉及的主要知识点有:验证码的基本原理、Asp.Net内置Captcha控件的使用、自定义服务器控件的开发、纯代码实现验证码的逻辑以及验证码的显示和验证。通过分析提供的文件名,我们可以推测这些...

    用asp.net生成随机验证码(全源码,附注释)

    用asp.net生成随机验证码(全源码,附注释)

    用asp.net生成随机验证码.rar_.NET验证码_asp.net_asp.net C#_生成验证码_验证码

    在ASP.NET框架下,我们可以利用C#编程语言来实现一个高效且安全的随机验证码生成器。本文将详细介绍如何在ASP.NET环境中创建一个基于C#的验证码生成器。 首先,我们需要理解验证码的基本构成。一个有效的验证码通常...

    asp.net 完美随机验证码

    在这个"asp.net 完美随机验证码"的主题中,我们将深入探讨如何在ASP.NET中实现一个功能完善的、随机性良好的验证码系统。 验证码的主要目的是防止自动化程序(如机器人)进行非法操作,例如注册、登录或提交表单。...

    asp.net短信登录验证码和图片验证程序源码

    资源名:asp.net短信登录验证码和图片验证程序源码 资源类型:程序源代码 源码说明: 1.实现了验证码倒计时的功能 1.以下验证码例子采用的是先获取手机号文字验证码,如果文字验证码收不到,将采用语音播放验证码的...

    asp.net生成图形验证码

    通过"图形验证码生成_asp.net"这个项目,开发者可以学习到如何在ASP.NET环境中实现一个完整的图形验证码系统,包括生成、发送、验证和安全防护等多个环节,这些知识对于构建更安全的Web应用非常有价值。

    ASP.NET多种生成验证码方法源码

    1. **随机字母与数字验证码**:这种验证码由随机生成的字母(包括大小写)和数字组成,它们以某种顺序排列,可以设置长度和复杂度,以增加破解难度。 2. **添加干扰元素的验证码**:为了增加自动化程序识别的难度,...

    asp.net 生成随机汉字验证码以及验证

    在ASP.NET开发中,生成随机汉字验证码是一种常见的安全措施,用于防止自动化的恶意攻击,比如机器人注册、垃圾信息提交等。这种验证码通过显示一组难以由机器识别的随机汉字,要求用户输入以完成验证,增加了非人类...

    【ASP.NET编程知识】ASP.NET生成图形验证码的方法详解.docx

    下面是一个简单的 ASP.NET 生成图形验证码的实现代码: ```csharp using System; using System.Configuration; using System.Data; using System.Linq; using System.Web; using System.Web.Security; using System....

    用asp.net生成随机验证码(全源码,附注释)

    在这个场景中,我们关注的是如何在 ASP.NET 中生成随机验证码,这是一个常见的安全措施,用于防止自动化的机器人或恶意用户进行非法操作,如垃圾邮件提交或账户注册。 验证码(CAPTCHA)的基本原理是生成一段随机的...

    用asp.net生成随机验证码(全源码,附注释).rar

    用asp.net生成随机验证码(全源码,附注释).rar

    ASP.NET动态验证码

    总之,ASP.NET动态验证码的实现涉及到字符串随机生成、图像处理和服务器端验证等多个环节。通过合理的设计和实现,动态验证码可以有效提升网站的安全性,阻止自动化攻击。同时,根据实际需求调整验证码的难度和外观...

    .net 随机生成验证码

    本文将详细解析如何在ASP.NET中生成随机验证码,包括其设计思路、代码实现以及背后的技术原理。 #### 核心知识点解析 1. **ASP.NET与验证码生成**: ASP.NET是一种广泛使用的Web开发框架,它提供了丰富的工具和...

Global site tag (gtag.js) - Google Analytics