本篇文章借阅了网上的其他文章,我自己又实践修改之后总结如下:

1.首先我们先建立一个验证码页面(取名Vcode.aspx)

我们进入到他的后台(Vcode.aspx.cs)书写验证码的生成方法:

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.Drawing.Imaging;public partial class VCode : System.Web.UI.Page
{protected void Page_Load(object sender, EventArgs e){VCode v = new VCode();string code = v.CreateVerifyCode();            //取随机码  v.CreateImageOnPage(code, this.Context);       // 输出图片  Session["CheckCode"] = code; }#region  验证码长度(默认6个验证码的长度)int length = 4;public int Length{get { return length; }set { length = value; }}#endregion#region 验证码字体大小(为了显示扭曲效果,默认40像素,可以自行修改)int fontSize = 40;public int FontSize{get { return fontSize; }set { fontSize = value; }}#endregion#region 边框补(默认1像素)int padding = 2;public int Padding{get { return padding; }set { padding = value; }}#endregion#region 是否输出燥点(默认不输出)bool chaos = true;public bool Chaos{get { return chaos; }set { chaos = value; }}#endregion#region 输出燥点的颜色(默认灰色)Color chaosColor = Color.LightGray;public Color ChaosColor{get { return chaosColor; }set { chaosColor = value; }}#endregion#region 自定义背景色(默认白色)Color backgroundColor = Color.White;public Color BackgroundColor{get { return backgroundColor; }set { backgroundColor = value; }}#endregion#region 自定义随机颜色数组Color[] colors = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown, Color.DarkCyan, Color.Purple };public Color[] Colors{get { return colors; }set { colors = value; }}#endregion#region 自定义字体数组string[] fonts = { "Arial", "Georgia" };public string[] Fonts{get { return fonts; }set { fonts = value; }}#endregion#region 自定义随机码字符串序列(使用逗号分隔)string codeSerial = "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,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";public string CodeSerial{get { return codeSerial; }set { codeSerial = value; }}#endregion#region 产生波形滤镜效果private const double PI = 3.1415926535897932384626433832795;private const double PI2 = 6.283185307179586476925286766559;/// <summary>  /// 正弦曲线Wave扭曲图片(Edit By 51aspx.com)  /// </summary>  /// <param name="srcBmp">图片路径</param>  /// <param name="bXDir">如果扭曲则选择为True</param>  /// <param name="nMultValue">波形的幅度倍数,越大扭曲的程度越高,一般为3</param>  /// <param name="dPhase">波形的起始相位,取值区间[0-2*PI)</param>  /// <returns></returns>  public System.Drawing.Bitmap TwistImage(Bitmap srcBmp, bool bXDir, double dMultValue, double dPhase){System.Drawing.Bitmap destBmp = new Bitmap(srcBmp.Width, srcBmp.Height);// 将位图背景填充为白色   System.Drawing.Graphics graph = System.Drawing.Graphics.FromImage(destBmp);graph.FillRectangle(new SolidBrush(System.Drawing.Color.White), 0, 0, destBmp.Width, destBmp.Height);graph.Dispose();double dBaseAxisLen = bXDir ? (double)destBmp.Height : (double)destBmp.Width;for (int i = 0; i < destBmp.Width; i++){for (int j = 0; j < destBmp.Height; j++){double dx = 0;dx = bXDir ? (PI2 * (double)j) / dBaseAxisLen : (PI2 * (double)i) / dBaseAxisLen;dx += dPhase;double dy = Math.Sin(dx);// 取得当前点的颜色  int nOldX = 0, nOldY = 0;nOldX = bXDir ? i + (int)(dy * dMultValue) : i;nOldY = bXDir ? j : j + (int)(dy * dMultValue);System.Drawing.Color color = srcBmp.GetPixel(i, j);if (nOldX >= 0 && nOldX < destBmp.Width&& nOldY >= 0 && nOldY < destBmp.Height){destBmp.SetPixel(nOldX, nOldY, color);}}}return destBmp;}#endregion#region 生成校验码图片public Bitmap CreateImageCode(string code){int fSize = FontSize;int fWidth = fSize + Padding;int imageWidth = (int)(code.Length * fWidth) + 4 + Padding * 2;int imageHeight = fSize * 2 + Padding;System.Drawing.Bitmap image = new System.Drawing.Bitmap(imageWidth, imageHeight);Graphics g = Graphics.FromImage(image);g.Clear(BackgroundColor);Random rand = new Random();//给背景添加随机生成的燥点  if (this.Chaos){Pen pen = new Pen(ChaosColor, 0);int c = Length * 10;for (int i = 0; i < c; i++){int x = rand.Next(image.Width);int y = rand.Next(image.Height);g.DrawRectangle(pen, x, y, 1, 1);}}int left = 0, top = 0, top1 = 1, top2 = 1;int n1 = (imageHeight - FontSize - Padding * 2);int n2 = n1 / 4;top1 = n2;top2 = n2 * 2;Font f;Brush b;int cindex, findex;//随机字体和颜色的验证码字符  for (int i = 0; i < code.Length; i++){cindex = rand.Next(Colors.Length - 1);findex = rand.Next(Fonts.Length - 1);f = new System.Drawing.Font(Fonts[findex], fSize, System.Drawing.FontStyle.Bold);b = new System.Drawing.SolidBrush(Colors[cindex]);if (i % 2 == 1){top = top2;}else{top = top1;}left = i * fWidth;g.DrawString(code.Substring(i, 1), f, b, left, top);}//画一个边框 边框颜色为Color.Gainsboro  g.DrawRectangle(new Pen(Color.Gainsboro, 0), 0, 0, image.Width - 1, image.Height - 1);g.Dispose();//产生波形(Add By 51aspx.com)  image = TwistImage(image, true, 8, 4);return image;}#endregion#region 将创建好的图片输出到页面public void CreateImageOnPage(string code, HttpContext context){System.IO.MemoryStream ms = new System.IO.MemoryStream();Bitmap image = this.CreateImageCode(code);image.Save(ms, ImageFormat.Jpeg);context.Response.ClearContent();context.Response.ContentType = "image/Jpeg";context.Response.BinaryWrite(ms.GetBuffer());ms.Close();ms = null;image.Dispose();image = null;}#endregion#region 生成随机字符码public string CreateVerifyCode(int codeLen){if (codeLen == 0){codeLen = Length;}string[] arr = CodeSerial.Split(',');string code = "";int randValue = -1;Random rand = new Random(unchecked((int)DateTime.Now.Ticks));for (int i = 0; i < codeLen; i++){randValue = rand.Next(0, arr.Length - 1);code += arr[randValue];}return code;}public string CreateVerifyCode(){return CreateVerifyCode(0);}#endregion
}

2.我们新建一个登录页面(取名Login.aspx),在他的前台页面添加一个image控件

我这里加的是html控件 也可以加.net控件

<img id="img_code" src="Vcode.aspx" alt="点击刷新验证码" onclick="f_refreshtype()" width="70px"/>

然后你再运行Login页面就可以看到你的图片变成了图片验证码。

3.验证码的点击刷新:

我们进入到Login的前台页面(Login.aspx),在他的头部head引入JQuery

接着在引入JQuery下面添加js代码:

注意:getElementById中添加的id要和你添加的image的id一样。

函数名字f_refreshtype()要和你img控件里写的οnclick="f_refreshtype()一样

<script src="../js/jquery.js" type="text/javascript"></script><script src="../js/jquery.min.js" type="text/javascript"></script><script language="javascript" type="text/javascript">function f_refreshtype() {var Image1 = document.getElementById("img_code");if (Image1 != null) {Image1.src = Image1.src + "?";}}</script>

4.验证验证码输入是否正确

在点击事件的动态代码里写

        string vCode = Session["CheckCode"].ToString();//获取生成的验证码if (输入验证码的控件.Text.Trim().ToUpper() == vCode.ToUpper()){//验证码正确}  else{//验证码错误}

ASP.NET中使用JQuery生成登陆验证码相关推荐

  1. 在ASP.NET中上传图片并生成缩略图

    在ASP.NET中上传图片并生成缩略图,可以参照下列代码: private void btnUploadPicture_Click(object sender, System.EventArgs e) ...

  2. asp.net中上传图片并生成小图片,自动添加水印的代码 .

    asp.net中上传图片并生成小图片,自动添加水印的代码 分类: .Net(C#) 2010-03-22 15:28 242人阅读 评论(0) 收藏 举报 /// 上传图片生成缩略图及水印 (来自:h ...

  3. 在asp.net中使用jQuery实现类似QQ网站的图片切割效果

    今天要给大家介绍一个asp.net结合jQuery来切割图片的小程序,原理很简单,大致流程是: 加载原图 --> 用矩形框在原图上选取区域并将选取的顶点坐标和矩形尺寸发送至服务器 --> ...

  4. 在Asp.net中使用JQuery插件之jTip

    jTip 是个轻量级的提示插件.默认支持两个参数: width宽度,default value :250px link 要link的URL 对应的Source code是: 1: var params ...

  5. ASP.NET中利用JQuery AJAX修改用户密码

    一.新建数据库,在项目App_Data右击,添加一个数据库,新建一个UserInfo表,表里设UserName,Password两个字段 二.新建一个Default.aspx页面,用表格简单布局,代码 ...

  6. ASP.NET中的随机密码生成

    第一种方法: 用.NET中的 Sytem.Guid.NewGuid().ToString() 生成,实际上是对一个128bit数字的十六进制输出. 生成的字符由0-9和a-z这几种字符组成,也可能会有 ...

  7. 如何在asp.net中动态生成验证码

    现在越来越多的网站喜欢搞个验证码出来,而且各个语言基本上都能做到,今天我来一个C#写的! using System; using System.Collections; using System.Co ...

  8. 【项目】springboot中使用kaptcha生成验证码,登录时密码加盐处理

    记录使用kaptcha的过程 为前后端分离项目,前端vue框架 文章目录 0.下载jar包 1.添加依赖 2.添加KaptchaConfig配置 3.后端用于登录的封装类编写 4.修改controll ...

  9. SpringMvc项目中使用GoogleKaptcha 生成验证码

    前言:google captcha 是google生成验证码的一个工具类,其原理是将随机生成字符串保存到session中,同时以图片的形式返回给页面,之后前台页面提交到后台进行对比. 1.jar包准备 ...

  10. 在JSP中动态生成随机验证码,登录时后台校验验证码,以及如何避免同一个验证码被重复提交爆破密码...

    只需几步就可以生成动态随机的验证码,最终效果如下图: 一 前台显示页面login.jsp 其中验证码显示的是一张图片,链接指向的是生成验证码的servlet,同时点击图片后触发changeImg()这 ...

最新文章

  1. 帝国Cms虚拟主机突破上传最大文件2m的限制的方法
  2. LeetCode Unique Binary Search Trees(dp)
  3. golang中的time详情
  4. 一维正态分布、二维正态分布的matlab实现
  5. boost::container模块实现范围分配器适配器
  6. css3 下边框缓缓划过_一篇文章带你了解CSS3按钮知识
  7. The Real Time Linux and RT Applications | PREEMPT_RT
  8. Linux内核编程11期:设备树(device tree)
  9. 四叶草Clover引导界面的快捷键大全
  10. qq音乐api接口梳理
  11. 【目标检测】SSD算法
  12. 杭州雄迈拟召回一万个网络摄像头:被指引发美国网络瘫痪
  13. php实现微信公众号群发消息接口(thinkphp3.2.3)
  14. 入门级概述光学相干层析(OCT)原理
  15. 计算机论文投tmc期刊,无线网络会议与期刊档次划分一览
  16. 带宽、传输速率、吞吐量的概念区别
  17. 目前商店巡店督导遇到的问题要怎么管理
  18. Unity TouchScripts实例 - 判断在物体上滑动
  19. 使用双重while循环求百钱百鸡问题
  20. unity画一条流动的弧线(贝塞尔线)

热门文章

  1. phpcms V9.6.0版本整合百度ueditor1.4.3.2,包括水图片上传水印
  2. Android Makefile and build system 分析
  3. 【编程好习惯】使用sizeof减少内存操作失误
  4. C# 让应用程序只运行一个实例
  5. Unity用GUI绘制Debug/print窗口/控制台-打包后测试
  6. RxJava -- 从 create 开始 (一)
  7. firebug 调试
  8. OEM XP 让你的盗版xp像品牌机一样华丽
  9. qemu前后端features协商过程分析(vhost_user后端)
  10. doc.project java_GitHub - kanghaimeng/idoc: Generate doc for java maven project.(java 项目自动生成文档)...