首先分析一下這份代碼中的不足(自己覺得的):
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();
//
PS:記得剛出來工作的時候代碼寫得很差(比現在差),一般拿到一份代碼都是直接用,從來沒有想過是否要把代碼進行修改或者封裝,那時候被我的師傅教導了一次印象很深刻。個人感覺其實用別人的代碼沒什么不好的,一來別人用過至少證明代碼的可用性,另外智商有限,有些東西自己想破頭皮也沒有別人想的好,但是用別人的代碼一定不要盲目地拿了就用,最好根據自己的實際情況進行必要的修改或者封裝,哪怕是簡單的隔一層也好。當然了,還是那句話,如果項目緊急的話這樣做明顯是浪費時間的,總之就是不要不思考,拿了就用,至少看把關鍵的代碼或者代碼的整體結構弄清楚。
腳本之家直接都給打包了。上面是old文件夾,下面的是new文件夾的內容。下載地址 /201012/yuanma/yanzhengma.rar
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com