• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > ASP.NET验证码(3种)

ASP.NET验证码(3种)

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了验证码 asp.net,二维码生成 asp.net,asp.net,asp net培训,asp和asp.net的区别等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

日常生活中我们在使用网站时都会遇到验证码,大家有没有想过为什么要使用验证码?

其实验证码的作用就是防止恶意破解密码、刷票、论坛灌水、刷页。有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方式进行不断的登录尝试。今天就跟大家分享ASP.NET的三种验证码。

1.GSC_WebControlLibrary 这是在网上找到的一个控件,非常好用。但是效果不是特别好(见下图。
)虽然容易使用,所有的属性都可以像控件一样设置,但是可用性不太高。用户不能自定义,而且看起来这个验证码效果不太好。

效果:

2.用一个页面生成图片,另一个页面调用,验证码存入cookie,调用时取cookie对比验证.这个用户就可以按自己的喜好更改效果和验证码的长度了。

效果如图:

CheckCode.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.Drawing2D;
using System.Drawing.Imaging;

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

  }

  private string GenerateCheckCode()
  {
    int number;
    char code;
    string checkCode = String.Empty;

    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;
  }

  private void CreateCheckCodeImage(string checkCode)
  {
    if (checkCode == null || checkCode.Trim() == String.Empty)
      return;

    System.Drawing.Bitmap image = new System.Drawing.Bitmap((int)Math.Ceiling((checkCode.Length * 12.5)), 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.GreenYellow), x1, y1, x2, y2);
      }

      Font font = new System.Drawing.Font("Verdana", 12, (System.Drawing.FontStyle.Bold | System.Drawing.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);
      g.DrawString(checkCode, font, brush, 2, 2);

      //画图片的前景噪音点
      for (int i = 0; i < 80; 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.Red), 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();
    }
  }


}

</div>

然后在需要使用的页面引用:
UseCheckCode.aspx

<img src="Tools/CheckCode.aspx" alt="验证码" style="width: 60px; height: 24px" />
</div>

3.用web handler生成图片。这个其实和前面的意思大致差不多,调用方法也基本和2一样,不同的是,它的验证码是存入Session的。供学习参考。

效果图如下:

ValidateImageHandler.ashx

%@ WebHandler Language="C#" Class="ValidateImageHandler" %>

using System;
using System.Web;
using System.Web.SessionState;
using System.Drawing;
using System.Drawing.Imaging;
using System.Text;

/// <summary>
/// ValidateImageHandler 生成网站验证码功能
/// </summary>
public class ValidateImageHandler : IHttpHandler, IRequiresSessionState
{
  int intLength = 5;        //长度
  string strIdentify = "Identify"; //随机字串存储键值,以便存储到Session中
  public ValidateImageHandler()
  {    
  }

  /// <summary>
  /// 生成验证图片核心代码
  /// </summary>
  /// <param name="hc"></param>
  public void ProcessRequest(HttpContext hc)
  {
    //设置输出流图片格式
    hc.Response.ContentType = "image/gif";
    
    Bitmap b = new Bitmap(200, 60);
    Graphics g = Graphics.FromImage(b);
    g.FillRectangle(new SolidBrush(Color.YellowGreen), 0, 0, 200, 60);
    Font font = new Font(FontFamily.GenericSerif, 48, FontStyle.Bold, GraphicsUnit.Pixel);
    Random r = new Random();

    //合法随机显示字符列表
    string strLetters = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
    StringBuilder s = new StringBuilder();
    
    //将随机生成的字符串绘制到图片上
    for (int i = 0; i < intLength; i++)
    {
      s.Append(strLetters.Substring(r.Next(0, strLetters.Length - 1), 1));
      g.DrawString(s[s.Length - 1].ToString(), font, new SolidBrush(Color.Blue), i * 38, r.Next(0, 15));
    }

    //生成干扰线条
    Pen pen = new Pen(new SolidBrush(Color.Blue), 2);
    for (int i = 0; i < 10; i++)
    {
      g.DrawLine(pen, new Point(r.Next(0, 199), r.Next(0, 59)), new Point(r.Next(0, 199), r.Next(0, 59)));
    }
    b.Save(hc.Response.OutputStream, ImageFormat.Gif);
    hc.Session[strIdentify] = s.ToString(); //先保存在Session中,验证与用户输入是否一致
    hc.Response.End();
  
  }
  
  /// <summary>
  /// 表示此类实例是否可以被多个请求共用(重用可以提高性能)
  /// </summary>
  public bool IsReusable
  {
    get
    {
      return true;
    }
  }
}
</div>

以上就是ASP.NET3种验证码,各有各的优缺点,希望大家可以熟练实现不同验证码的功能。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ASP.NET中画图形验证码的实现代码
  • Asp.net开发之webform图片水印和图片验证码的实现方法
  • Asp.net开发之webform图片水印和图片验证码的实现方法
  • ASP.NET生成二维码的方法总结
  • ASP.NET生成图形验证码的方法详解
  • 详解ASP.NET验证码的生成方法
  • asp.net生成字母和数字混合图形验证码
  • asp.net简单生成验证码的方法
  • ASP.NET验证码实现(附源码)
  • asp.net中的窗体身份验证(最简单篇)

相关文章

  • 2017-05-11使用 ServiceStack.Text 序列化 json的实现代码
  • 2017-05-11Asp.net中把Excel数据存储至SQL Server中的具体实现方法
  • 2017-05-11ASP.NET MVC3 实现全站重定向的简单方法
  • 2017-05-11ASP.NET微信公众号添加菜单
  • 2017-05-11.net MVC 连接数据本地数据库三种方法总结
  • 2018-08-20asp.net core 2.0 webapi集成signalr(实例讲解)
  • 2017-05-11ASP.NET数据库编程之Access连接失败
  • 2018-08-20ASP.NET Core 2.0 WebApi全局配置及日志实例
  • 2017-05-11Asp.net 菜单控件简洁版
  • 2017-05-11ASP.Net获取客户端网卡MAC的小例子

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Request.RawUrl 属性的应用收
    • 告别ADO.NET实现应用系统无缝切换的烦恼(总结篇)
    • ASP.NET MVC:Filter和Action的执行介绍
    • 使用DataGrid中扩展ItemRenderer和HeaderRenderer进行操作
    • ASP.NET/C#中如何调用动态链接库DLL
    • ASP.NET与ASP互通COOKIES的一点经验
    • asp.net 动态输出透明gif图片
    • 如何为asp.net网站项目添加子项目
    • ASP.NET Web API教程 创建Admin视图详细介绍
    • ASP.NET MVC5网站开发管理列表、回复及删除(十三)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有