zoukankan      html  css  js  c++  java
  • 发布一个很COOL的图片验证码程序[含源码]

    一、先看看效果:


    制作步骤:
    (1)准备你想要的多张图片(数量不限,由你自己决定),将它们放在一个统一的目录下,比如我这里是“ValidateCodeImg”。图片尺寸尽量适合你的验证码尺寸。这样有利于达到最佳性能比。

    (2)将以下代码分别COPY到你的工程目录下(记得放在ValidateCodeImg目录的上一级目录中)。

    二、相关代码:
    1、// ValidateCode.aspx页面:
    -----------------------------------------
    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="ValidateCode.aspx.cs" Inherits="Comm_ValidateCode" %>

    <!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>
    </head>
    <body>
        <form id="form1" runat="server">
        <div>
       
        </div>
        </form>
    </body>
    </html>

    2、// ValidateCode.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.Imaging;
    using System.IO;

    public partial class Comm_ValidateCode : System.Web.UI.Page
    {
        int _width = 75;
        int _height = 21;
    //    int _width = 128;
    //    int _height = 40;
        string imgDir = @"ValidateCodeImg";
        public int Width
        {
            get
            {
                return _width;
            }
            set
            {
                _width = value;
            }
        }

        public int Height
        {
            get
            {
                return _height;
            }
            set
            {
                _height = value;
            }
        }

        protected void Page_Load(object sender, EventArgs e)
        {
            if (Request.QueryString["w"] != null)
            {
                try
                {
                    this._width = int.Parse(Request.QueryString["w"].Trim());
                }
                catch (Exception exc)
                {
                    //
                }
            }
            if (Request.QueryString["h"] != null)
            {
                try
                {
                    this._height = int.Parse(Request.QueryString["h"].Trim());
                }
                catch (Exception exc)
                {
                    //
                }
            }
            //  4位数字的验证码
            if (!IsPostBack)
            {
                string str_ValidateCode = GetRandomNumberString(4);
                //用于验证的Session
                Session["ValidateCode"] = str_ValidateCode;
                CreateImage(str_ValidateCode);
            }
        }

        //  生成随机数字字符串
        public string GetRandomNumberString(int int_NumberLength)
        {
            string str_Number = string.Empty;
            Random theRandomNumber = new Random();

            for (int int_index = 0; int_index < int_NumberLength; int_index++)
                str_Number += theRandomNumber.Next(10).ToString();

            return str_Number;
        }

        //生成随机颜色
        public Color GetRandomColor()
        {
            Random RandomNum_First = new Random((int)DateTime.Now.Ticks);
            System.Threading.Thread.Sleep(RandomNum_First.Next(50));
            Random RandomNum_Sencond = new Random((int)DateTime.Now.Ticks);
            int int_Red = RandomNum_First.Next(256);
            int int_Green = RandomNum_Sencond.Next(256);
            int int_Blue = (int_Red + int_Green > 400) ? 0 : 400 - int_Red - int_Green;
            int_Blue = (int_Blue > 255) ? 255 : int_Blue;

            return Color.FromArgb(int_Red, int_Green, int_Blue);
        }

        public FileInfo[] GetAllFilesInPath(string path)
        {
            System.IO.DirectoryInfo di = new DirectoryInfo(path);

            return di.GetFiles("*.jpg", SearchOption.TopDirectoryOnly);
        }

        public string GetRandomFile(string path)
        {
            FileInfo[] fi = this.GetAllFilesInPath(path);
            Random rand = new Random(new Guid().GetHashCode() + (int)DateTime.Now.Ticks);
            int k = rand.Next(0, fi.Length);

            return fi[k].FullName;
        }

        public int GetRandomAngle()
        {
            Random rand = new Random((int)DateTime.Now.Ticks);
            System.Threading.Thread.Sleep(rand.Next(50));
            return rand.Next(-45, 45);
        }

        //根据验证字符串生成最终图象
        public void CreateImage(string str_ValidateCode)
        {
            //int int_ImageWidth = str_ValidateCode.Length * 13;
            //int width = int_ImageWidth;
            int int_ImageWidth = this.Width;
            int width = int_ImageWidth;

            int height = this.Height;

            string filePath = Server.MapPath(imgDir);
            Bitmap bgImg = (Bitmap)Bitmap.FromFile(GetRandomFile(filePath));

            Random newRandom = new Random();
            //  图高20px
            Bitmap theBitmap = new Bitmap(width, height);
            Graphics theGraphics = Graphics.FromImage(theBitmap);
            theGraphics.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic;
            theGraphics.CompositingQuality = System.Drawing.Drawing2D.CompositingQuality.HighQuality;
            theGraphics.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
            theGraphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias;
            //  白色背景
            //theGraphics.Clear(Color.White);
            theGraphics.DrawImage(bgImg, new Rectangle(0, 0, width, height), new Rectangle(0, 0, bgImg.Width, bgImg.Height), GraphicsUnit.Pixel);
            //  灰色边框
            theGraphics.DrawRectangle(new Pen(Color.LightGray, 1), 0, 0, int_ImageWidth - 1, height - 1);

            //13pt的字体
            float fontSize = this.Height * 1.0f / 1.38f;
            float fontSpace = fontSize / 7f;
            Font theFont = new Font("Arial", fontSize);
            System.Drawing.Drawing2D.GraphicsPath gp = null;
            System.Drawing.Drawing2D.Matrix matrix;
            for (int int_index = 0; int_index < str_ValidateCode.Length; int_index++)
            {
                string str_char = str_ValidateCode.Substring(int_index, 1);
                Brush newBrush = new SolidBrush(GetRandomColor());
                Point thePos = new Point((int)(int_index * (fontSize + fontSpace) + newRandom.Next(3)), 1 + newRandom.Next(3));
                gp = new System.Drawing.Drawing2D.GraphicsPath();
                gp.AddString(str_char, theFont.FontFamily, 0, fontSize, thePos, new StringFormat());
                matrix = new System.Drawing.Drawing2D.Matrix();
                int angle = GetRandomAngle();
                PointF centerPoint = new PointF(thePos.X + fontSize / 2, thePos.Y + fontSize / 2);
                matrix.RotateAt(angle, centerPoint);
                theGraphics.Transform = matrix;
                theGraphics.DrawPath(new Pen(Color.White, 2f), gp);
                //theGraphics.FillPath(new SolidBrush(Color.Black), gp);
                theGraphics.FillPath(new SolidBrush(GetRandomColor()), gp);
                theGraphics.ResetTransform();
            }

            if (gp != null) gp.Dispose();

            //  将生成的图片发回客户端
            MemoryStream ms = new MemoryStream();
            theBitmap.Save(ms, ImageFormat.Png);

            Response.ClearContent(); //需要输出图象信息 要修改HTTP头
            Response.ContentType = "image/Png";
            Response.BinaryWrite(ms.ToArray());
            theGraphics.Dispose();
            theBitmap.Dispose();
            Response.End();
        }
    }
     
    三、如何使用?
    1、引用验证码图形时:
    <img src="ValidateCode.aspx?w=100&h=32" id="ValidateCodeAuto" width="100" height="32" align="absmiddle" /> &nbsp; <a href="#" onclick="Javascript:var now=new Date();var number = now.getSeconds(); document.getElementById('ValidateCodeAuto').src='ValidateCode.aspx?w=100&h=32&dd=' + number;">看不清楚</a>
    2、验证时,判断用户输入验证码是否等于 Session["ValidateCode"] 即可。
    3、其他说明:(1)上面有两个参数w和h,是用来定义图形验证码大小的。比如你想将你验证码设置为128*40时,你只需要ValidateCode.aspx?w=128&h=40,然后将图片引用后面的Width,Height改成:width="128" height="40" 即可。对应的,看不清楚的Javascript代码也需要将src='ValidateCode.aspx?w=100&h=32改成:src='ValidateCode.aspx?w=128&h=40。
    (2)“看不清楚”处还有一个参数dd,是用来做生成随机值以便更新验证码图片的。

  • 相关阅读:
    2010年10月全球web服务器调查
    Orchard 发布1.0版本和ASP.NET MVC 3 RTM
    推荐一个在Linux/Unix上架设ASP.NET的 WEB服务器Jexus
    Windows Azure 的成本架构
    RavenDB系列教程
    Mono环境下不支持中文的解决方法
    IIS 7.0的六大安全新特性为你的Web服务器保驾护航
    Windows 7 Phone 文档数据库Rapid Repository正式发布
    使用log4Net 输出日志到mongodb
    Ubuntu & Fedora Mono 2.8 安装脚本
  • 原文地址:https://www.cnblogs.com/yamajia/p/958205.html
Copyright © 2011-2022 走看看