验证码图片生成

下面是Vb的   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>  
  <FONT   face="宋体"></FONT>  
  ----------------------------------------------  
  上面一个单独的页面,图片大小可以自己调  
   
  在你要用的页面里加入一个图片控件  
  <asp:image   id="image1"   runat="server"   imageurl="gif.aspx"   />  
   
  调用的时候可以用   Session["vnum"]  
    Session的值就是图片的值,可以作为验证  

---------------------------------------------------------------------------------------------------------------

    那么又应该如何使用该文件生成的图象验证码,看这句代码:
 <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

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
生成验证码图片可以使用 Python 中的 Pillow 库和随机数库,具体步骤如下: 1. 导入需要的库: ```python from PIL import Image, ImageDraw, ImageFont import random ``` 2. 定义生成随机字符串的函数: ```python def generate_random_str(length): # 定义随机字符串的备选值 candidates = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ' # 从备选值中随机选择指定长度的字符串 return ''.join(random.choices(candidates, k=length)) ``` 3. 定义生成验证码图片的函数: ```python def generate_verification_code(width, height, length): # 创建画布 image = Image.new('RGB', (width, height), color=(255, 255, 255)) # 创建画笔 draw = ImageDraw.Draw(image) # 设置字体 font = ImageFont.truetype('arial.ttf', size=30) # 生成随机字符串 code = generate_random_str(length) # 在画布上绘制字符串 for i in range(length): draw.text((10 + i * 20, 10), code[i], font=font, fill=random.choice([(0, 0, 0), (255, 0, 0), (0, 0, 255)])) # 添加干扰点 for i in range(100): draw.point((random.randint(0, width), random.randint(0, height)), fill=(0, 0, 0)) # 添加干扰线 for i in range(5): draw.line([(random.randint(0, width), random.randint(0, height)), (random.randint(0, width), random.randint(0, height))], fill=(0, 0, 0)) # 返回验证码图片和对应的字符串 return image, code ``` 4. 调用函数生成验证码图片: ```python image, code = generate_verification_code(120, 40, 4) image.show() ``` 以上代码中,`generate_random_str` 函数用于生成指定长度的随机字符串,`generate_verification_code` 函数用于生成指定宽度、高度和长度的验证码图片,并返回图片对象和对应的字符串。在绘制字符串时,使用了随机的字体颜色,以及添加了干扰点和干扰线,增加了验证码的复杂度。最后调用 `show` 方法显示生成验证码图片
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值