封装的一个asp.net验证码类
首先分析一下这份代码中的不足(自己觉得的):
1、面向过程式的编程,如果要修改验证码的属性,例如修改字体的大小、背景颜色等细节的东西,需要去一般处理程序中找到相关的代码,修改之。不过这份代码比较好,把生成验证码字符串和生成图片用不同的方法分开,很容易找到要修改的地方。
2、如果我想把这个功能应用到其他地方,例如winform程序中,那么这份代码没办以一个组件(一个dll)形式被复用,而是被复制粘贴然后修改...
3、没有发现验证码生成之后有存起来(- -!)
当然,所谓的不足是相对而言的,就是有时间来思考然后慢慢设计一个验证码类的话肯定能作出一个比较不错的类出来的,但如果是在做项目并且项目很紧急的话,这样的代码其实是比较给力的,那些所谓的面向对象设计模式代码解耦啥的都是浮云~~~
接下来是我对这份代码的修改,首先确定自己要什么样的效果,就是说封装起来后我希望怎样来使用他。首先我希望在使用的时候只需要new一个验证码实例(需要的话可以对验证码的各个属性可以任意设置),然后可以调用这个实例的某些方法分别以字符串、流、位图对象、byte数组的形式获取到这个验证码(说明,这个验证码类不包括把验证码存进上下文的功能,个人觉得生成验证码和把验证码存到上下文是两种不同的功能,没必要把这功能做到验证码类中去)。这样的话在一般处理程序中代码就变得异常简单了,首先只要new出一个验证码,然后调用方法以字符串的形式获取到这个验证码,然后存到上下午中,至于存在Session中或者Cookie中就按照需要来了,验证码类不管这些的;然后是调用另外一个方法以byte数组的形式获取到这个验证码,这样通过context.Response.BinaryWrite()方法就可以输出图片了,也就是说一般处理程序中只有三句代码。调用的代码大致如下:
/// <summary> /// 获取验证码(一般处理程序入口函数) /// </summary> /// <param name="context">当前上下文</param> public void ProcessRequest(HttpContext context) { // 创建验证码 ValidateCode validateCode = new ValidateCode(); // 获取验证码(字符串),写入Session context.Session["SomeValidateCode"] = validateCode.GetString(); // 输出验证码(图片) context.Response.BinaryWrite(validateCode.GetByteArray()); }
PS:记得刚出来工作的时候代码写得很差(比现在差),一般拿到一份代码都是直接用,从来没有想过是否要把代码进行修改或者封装,那时候被我的师傅教导了一次印象很深刻。个人感觉其实用别人的代码没什么不好的,一来别人用过至少证明代码的可用性,另外智商有限,有些东西自己想破头皮也没有别人想的好,但是用别人的代码一定不要盲目地拿了就用,最好根据自己的实际情况进行必要的修改或者封装,哪怕是简单的隔一层也好。当然了,还是那句话,如果项目紧急的话这样做明显是浪费时间的,总之就是不要不思考,拿了就用,至少看把关键的代码或者代码的整体结构弄清楚。
更封装的一个asp.net验证码类相关文章请关注PHP中文网!