电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 在线教程-> .NET
开发基于ASP.NET WebService的图片验证码服务-.NET教程,Asp.Net开发
作者:网友供稿 点击:4
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
 

最近,工作中接到一项任务,开发一个页面验证码功能,查阅了一些网上的资料,并结合以前的绘图方面的知识,实现了如下的解决方案。生成的验证码效果如图:

开发基于asp.net webservice的图片验证码服务

  要解决的问题:

  1. 如何随机生成图片

    生成system.drawing.bitmap对象,使用system.drawing.graphics向位图对象中绘图。

  2. 如何在webservice的方法中通过参数传递图片数据

    将bitmap对象输出成字节流,webmothod使用字节数组返回该字节流。

  实例:

  1. 用vs.net 2003创建一个asp.net webservice工程,默认的service名为myservice,为myservice添加一个名为generateverifyimage的webmethod。该方法的代码如下:

  /// <summary>
  /// 生成图片验证码
  /// </summary>
  /// <param name="nlen">验证码的长度</param>
  /// <param name="strkey">输出参数,验证码的内容</param>
  /// <returns>图片字节流</returns>
  [webmethod]
  public byte[] generateverifyimage(int nlen,ref string strkey)
  {
   int nbmpwidth = 13*nlen+5;
   int nbmpheight = 25;
   system.drawing.bitmap bmp = new system.drawing.bitmap(nbmpwidth,nbmpheight);

   // 1. 生成随机背景颜色
   int nred,ngreen,nblue;  // 背景的三元色
   system.random rd = new random((int)system.datetime.now.ticks);
   nred = rd.next(255)%128+128;
   ngreen = rd.next(255)%128+128;
   nblue = rd.next(255)%128+128;

   // 2. 填充位图背景
   system.drawing.graphics graph = system.drawing.graphics.fromimage(bmp);
   graph.fillrectangle(new solidbrush(system.drawing.color.fromargb(nred,ngreen,nblue))
    ,0
    ,0
    ,nbmpwidth
    ,nbmpheight);


   // 3. 绘制干扰线条,采用比背景略深一些的颜色
   int nlines = 3;
   system.drawing.pen pen = new system.drawing.pen(system.drawing.color.fromargb(nred-17,ngreen-17,nblue-17),2);
   for(int a =0;a< nlines;a++)
   {
    int x1 = rd.next() % nbmpwidth;
    int y1 = rd.next() % nbmpheight;
    int x2 = rd.next() % nbmpwidth;
    int y2 = rd.next() % nbmpheight;
    graph.drawline(pen,x1,y1,x2,y2);
   }

   // 采用的字符集,可以随即拓展,并可以控制字符出现的几率
   string strcode = "abcdefghijklmnopqrstuvwxyz"; 

   // 4. 循环取得字符,并绘制
   string strresult = "";
   for(int i=0;i<nlen;i++)
   {
    int x = (i*13 + rd.next(3));
    int y = rd.next(4) + 1;

    // 确定字体
    system.drawing.font font = new system.drawing.font("courier new",
     12 + rd.next()%4,
     system.drawing.fontstyle.bold);
    char c = strcode[rd.next(strcode.length)];  // 随机获取字符
    strresult += c.tostring();

    // 绘制字符
    graph.drawstring(c.tostring(),
     font,
     new solidbrush(system.drawing.color.fromargb(nred-60+y*3,ngreen-60+y*3,nblue-40+y*3)),
     x,
     y);
   }

   // 5. 输出字节流
   system.io.memorystream bstream = new system.io.memorystream();
   bmp.save(bstream,system.drawing.imaging.imageformat.jpeg);
   bmp.dispose();
   graph.dispose();

   strkey = strresult;
   byte[] bytereturn = bstream.toarray();
   bstream.close();

   return bytereturn;
  }

  2. 测试webmethod,添加一个webform,引用上述webservice,引用名为imagesvr。在page_load中添加代码:

   ...
   imagesvr.myservice imgsvr = new imagesvr.myservice();
   string strkey = "";
   byte[] data = imgsvr.generateverifyimage(5,ref strkey);
   response.outputstream.write(data,0,data.length);
   ...

  3. 运行。每次refresh这个webform时,就会显示一个新生成的图片验证码,而函数的输出参数strkey保存的就是这个验证码的实际内容,可以保存在session中,作为验证使用。

  上次开发出图片验证码之后,根据一些朋友的建议,本着验证码易识别(针对人),不易破解,美观的原则,改进了验证码生成的算法,采用图像滤镜的方法,对图片验证码进行反破解干扰,结果图片示例如下:
开发基于asp.net webservice的图片验证码服务

  滤镜效果主要采用波形(wave)算法,通过对x轴y轴的正弦波形处理,产生叠加效果。算法主要描述如下:

  private const double pi = 3.1415926535897932384626433832795;
  private const double pi2 = 6.283185307179586476925286766559;

  /// <summary>
  /// 正弦曲线wave扭曲图片
  /// </summary>
  /// <param name="srcbmp"></param>
  /// <param name="bxdir"></param>
  /// <param name="nmultvalue">波形的幅度倍数</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;
  }

  开头的示例图片,是两次波形效果的叠加,两次效果分别针对x轴方向和y轴方向,如果取消对边缘背景色的填充,可以看到算法对图形的影响,如下图:
开发基于asp.net webservice的图片验证码服务

  这样产生的验证码,看起来很像google站点上的验证码吧,当然,如果你有兴趣,还可以添加其他的滤镜效果,如拉伸,旋转,马赛克等。但是注意一点,网站验证码不是越复杂越好,要在速度和安全上找到一个平衡点。

转自:动态网站制作指南 | www.knowsky.com

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·经典收藏之 - C++内存管理详解-.NET教程,C#语言
·Master Page 初探-.NET教程,评论及其它
·GDI+编程10个基本技巧-.NET教程,评论及其它
·VB.NET中让Textbox只能输入数字(二)-.NET教程,VB.Net语言
·stl应用小问题-.NET教程,评论及其它
·WIN32中颜色值(COLORREF)与.NET中颜色值(Color)的转换-ASP教程,系统相关
·打造自己的专业图像工具-Visual C++ 2005图像编程系列【三】-.NET教程,C#语言
·.Net中常见问题及解决方法归类-.NET教程,.NET Framework
·Lex和Yacc从入门到精通(3)--一个极其简单的lex和yacc程序-.NET教程,评论及其它
·VB下几个非常有用的函数-.NET教程,VB.Net语言

最新文章
·VC#初学入门:第一个Windows程序
·ASP.NET 2.0-选用DataSet或DataReader
·用.net 处理xmlHttp发送异步请求
·asp.net创建文件夹的IO类的问题
·asp.net 2.0 中加密web.config 文件中的配置节
·关于ASP.NET调用JavaScript的实现
·如何实现ASP.NET网站个性化
·Acegi安全系统的配置-.NET教程,评论及其它
·Spring安全系统:Acegi Security Acegi简介-.NET教程,评论及其它
·Biztalk 开发之 架构和实例的验证-.NET教程,评论及其它


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号