当前位置: 首页 > news >正文

Asp.Net生成验证码(转)--------Good!

经常在论坛里看到有问怎么实现验证码的帖子,其实关于验证码的文章在csdn,dev-club等网站上都有很多,但是很多文章只讲诉了如何输出一个随机生成数字或字符的图象,当然了,这个是验证码的核心了,但是对很多asp.net的初学者来说,怎么使用它生成的图象又成了一个问题(论坛有不少问这个的),这也是我写本文的一个原因.
    言归正传,关于验证码的原理,我就不多说了,大家可以参见其他文章,文末附有完整的实例代码,里面有详细的注释,你可以跳过解说文字,直接使用
    首先,我要简要说说session和viewstate的用法,因为后面会用到它
       把数据存储在session中:session("key")="test"
       从session取值:dim testvalue as string=session("key")
      类似的:
       把数据存储在viewstate中:viewstate("key")="test"
       从viewstate中取值:dim testvalue as string=viewstate("key")
    关于viewstate的更详细的资料,你可以参看msdn的<<asp.net viewstate 初探>>一文
      百闻不如一见,有时代码本身就比任何解说更有表现力,所以在此就不对代码解说太多了,本文实现的验证码需要用到两个文件:
       gif.aspx           该文件用于生成验证码
       validatecode.aspx  该文件用来测试验证码(即如何使用)
   下面给出gif.aspx的完整代码:
<%@ import namespace="system"%>
<%@ import namespace="system.io"%>
<%@ import namespace="system.drawing"%>
<%@ import namespace="system.drawing.imaging"%>
<script language="vb" runat="server">
 sub page_load(sender as object,e as eventargs)
    'rndnum是一个自定义函数
    dim vnum as string=rndnum(4)
    session("vnum")=vnum
    validatecode(vnum)
 end sub
 '生成图象验证码函数
 sub validatecode(vnum)
   dim img as system.drawing.bitmap
   dim g as graphics
   dim ms as memorystream
   dim gheight as integer=int(len(vnum)*11.5)
   'gheight为图片宽度,根据字符长度自动更改图片宽度
   img=new bitmap(gheight,20)
   g=graphics.fromimage(img)
   g.drawstring(vnum,(new font("arial",10)),(new solidbrush(color.blue)),3,3)'在矩形内绘制字串(字串,字体,画笔颜色,左上x.左上y)
   ms=new memorystream()
   img.save(ms,imageformat.png)
   response.clearcontent() '需要输出图象信息 要修改http头
   response.contenttype="image/png"
   response.binarywrite(ms.toarray())
   g.dispose()
   img.dispose()
   response.end()
 end sub
  '--------------------------------------------
  '函数名称:rndnum
  '函数参数:vcodenum--设定返回随机字符串的位数
  '函数功能:产生数字和字符混合的随机字符串
  function rndnum(vcodenum)
    dim vchar as string="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,w,x,y,z"
    dim vcarray() as string=split(vchar,",") '将字符串生成数组
    dim vnum as string=""
    dim i as byte
    for i=1 to vcodenum
      randomize
      vnum=vnum & vcarray(int(35*rnd)) '数组一般从0开始读取,所以这里为35*rnd
    next
    return vnum
  end function
</script>
那么又应该如何使用该文件生成的图象验证码,看这句代码:
 <asp:image id="image1" runat="server" imageurl="gif.aspx" />
这就是用来显示验证码的image控件,你可以把它放在任何你喜欢的地方,下面的给出详细的使用代码,你把它保存为validatecode.aspx,并把它和gif.aspx放在同一目录下,在浏览器中打开validatecode.aspx,就可以测试它的效果了:
<script language="vb" runat="server">
  sub page_load(sender as object,e as eventargs)
      dim vnum as string=session("vnum")
      session.abandon()
      viewstate("vnum")=vnum
  end sub
  '下面的事件代码是用来测试验证码,可以根据需要更改
  sub btnsubmit_click(sender as object,e as eventargs)
      '判断输入的验证码与所给是否相同
      if txtvalidatecode.text=cstr(viewstate("vnum")) then
          lblshow.text="<font color='red'>提示:验证通过</font>"
      else
       lblshow.text="所填写的验证码与所给的不符"
      end if
  end sub
</script>
<html>
<body>
<form runat="server">
  <div align="center">
    <table width="750">
      <!--dwlayouttable-->
      <tr>
        <td width="256" height="46">&nbsp; </td>
        <td width="9">&nbsp;</td>
        <td width="88">&nbsp;</td>
        <td width="87">&nbsp;</td>
        <td width="100">&nbsp;</td>
        <td width="68">&nbsp;</td>
        <td width="97">&nbsp;</td>
      </tr>
      <tr>
        <td height="21"></td>
        <td></td>
        <td colspan="3" valign="top"><asp:label id="lblshow" runat="server"></asp:label></td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td height="14"></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
        <td></td>
      </tr>
      <tr>
        <td height="21">&nbsp;</td>
        <td colspan="2" valign="middle">验证码:</td>
        <td valign="top"><asp:image id="image1" runat="server" imageurl="gif.aspx" /></td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td height="20">&nbsp;</td>
        <td colspan="2" valign="top">输入验证码:</td>
        <td valign="top"><asp:textbox id="txtvalidatecode" runat="server" textmode="singleline" /></td>
        <td colspan="2" valign="middle"><font color="#ff0000" size="2">*注意:区分大小写</font></td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td height="25">&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
      </tr>
      <tr>
        <td height="19">&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td valign="top"><asp:button id="btnsubmit" runat="server" text="比较" οnclick="btnsubmit_click" /></td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
        <td>&nbsp;</td>
      </tr>
    </table>
  </div>
</form>
</body>
</html>

相关文章:

  • Visual C# 2005 - 如何利用程序代码产生多层次绘图效果
  • 关于mysql数据库中数据输入问题
  • 转载:写给计算机专业的朋友们
  • 一个用js写的导航(转)
  • 给msn 添加addin, 制作msn机器人
  • SAP-财务-统驭科目
  • 成长路上
  • 轻松为Windows系统快速配置多个网关
  • 正在加载页面loading的制作
  • [原创]PHP重定向三种方法
  • 新年----我一个人过
  • Request.UrlReferrer详解
  • 一个简单的HttpListener服务结构
  • javascript学习与实践(1)
  • 大型网站数据库优化和故障跟踪与排查(下篇)
  • 【node学习】协程
  • 【从零开始安装kubernetes-1.7.3】2.flannel、docker以及Harbor的配置以及作用
  • Codepen 每日精选(2018-3-25)
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • EventListener原理
  • jquery ajax学习笔记
  • Laravel深入学习6 - 应用体系结构:解耦事件处理器
  • SpiderData 2019年2月23日 DApp数据排行榜
  • SpingCloudBus整合RabbitMQ
  • Vue--数据传输
  • 初识 webpack
  • 从 Android Sample ApiDemos 中学习 android.animation API 的用法
  • 第2章 网络文档
  • 对超线程几个不同角度的解释
  • 驱动程序原理
  • 如何借助 NoSQL 提高 JPA 应用性能
  • 数据仓库的几种建模方法
  • 数组的操作
  • 说说动画卡顿的解决方案
  • 原生 js 实现移动端 Touch 滑动反弹
  • 源码安装memcached和php memcache扩展
  • $jQuery 重写Alert样式方法
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (day6) 319. 灯泡开关
  • (Forward) Music Player: From UI Proposal to Code
  • (待修改)PyG安装步骤
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (附源码)ssm失物招领系统 毕业设计 182317
  • (十七)Flask之大型项目目录结构示例【二扣蓝图】
  • (一)UDP基本编程步骤
  • (转)shell调试方法
  • .net 设置默认首页
  • .Net(C#)常用转换byte转uint32、byte转float等
  • .NET文档生成工具ADB使用图文教程
  • [1]-基于图搜索的路径规划基础
  • [20140403]查询是否产生日志
  • [AIGC codze] Kafka 的 rebalance 机制
  • [ai笔记3] ai春晚观后感-谈谈ai与艺术
  • [bzoj 3124][sdoi 2013 省选] 直径
  • [go] 迭代器模式