ASP.NET 验证码

 验证图片路径SRC 指向此页面 如src="***.aspx" // 如<img  src="GenerateCheckCode.aspx"/>

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.Imaging;

using System.IO;



public partial class Sate_Manager_GenerateCheckCode : System.Web.UI.Page

{

    protected void Page_Load(object sender, EventArgs e)

    {

        if (!this.IsPostBack)

        {

            string chkCode = string.Empty;

            //颜色列表,用于验证码、噪线、噪点  

            Color[] color = { Color.Black, Color.Red, Color.Blue, Color.Green, Color.Orange, Color.Brown, Color.Brown, Color.DarkBlue };

            //字体列表,用于验证码  

            string[] font = { "Times New Roman", "MS Mincho", "Book Antiqua", "Gungsuh", "PMingLiU", "Impact" };

            //验证码的字符集,去掉了一些容易混淆的字符  

            char[] character = { '2', '3', '4', '5', '6', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'R', 'S', 'T', 'W', 'X', 'Y' };

            Random rnd = new Random();

            //生成验证码字符串  

            for (int i = 0; i < 4; i++)

            {

                chkCode += character[rnd.Next(character.Length)];

            }

            Bitmap bmp = new Bitmap(65, 30);

            Graphics g = Graphics.FromImage(bmp);

            g.Clear(Color.White);

            /**/

            画噪线  

            //for (int i = 0; i < 10; i++)  

            //{  

            //    int x1 = rnd.Next(100);  

            //    int y1 = rnd.Next(40);  

            //    int x2 = rnd.Next(100);  

            //    int y2 = rnd.Next(40);  

            //    Color clr = color[rnd.Next(color.Length)];  

            //    g.DrawLine(new Pen(clr), x1, y1, x2, y2);  

            //}  

            //画验证码字符串  

            Session["code"] = chkCode;

            for (int i = 0; i < chkCode.Length; i++)

            {

                string fnt = font[rnd.Next(font.Length)];

                Font ft = new Font(fnt, 18);

                Color clr = color[rnd.Next(color.Length)];

                g.DrawString(chkCode[i].ToString(), ft, new SolidBrush(clr), (float)i * 12 + 4, (float)5);

            }



            //画噪点  

            for (int i = 0; i < 100; i++)

            {

                int x = rnd.Next(bmp.Width);

                int y = rnd.Next(bmp.Height);

                Color clr = color[rnd.Next(color.Length)];

                bmp.SetPixel(x, y, clr);

            }

            //清除该页输出缓存,设置该页无缓存  

            Response.Buffer = true;

            Response.ExpiresAbsolute = System.DateTime.Now.AddMilliseconds(0);

            Response.Expires = 0;

            Response.CacheControl = "no-cache";

            Response.AppendHeader("Pragma", "No-Cache");

            //将验证码图片写入内存流,并将其以 "image/Png" 格式输出  

            MemoryStream ms = new MemoryStream();

            try

            {

                bmp.Save(ms, ImageFormat.Png);

                Response.ClearContent();

                Response.ContentType = "image/Png";

                Response.BinaryWrite(ms.ToArray());

            }

            finally

            {

                //显式释放资源  

                bmp.Dispose();

                g.Dispose();

            }

        }

    }  

 }
实现单击图片换一张效果
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="ManagerLogin.aspx.cs" Inherits="Sate_Manager_ManagerLogin" %>



<!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 runat="server">

    <title>无标题页</title>

     <script type="text/javascript" language="javascript">

        function chang(obj)

        {        

        obj.src=obj.src+'?';

            

        }

        </script>

</head>

<body>

    <form id="form1" runat="server">    

       

        <img  src="GenerateCheckCode.aspx" οnclick="s(this)" />    

    </form>

</body>

</html>

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值