|
引言 最近和一位朋友探討獲取WebBrowser訪問(wèn)的網(wǎng)頁(yè)中驗(yàn)證圖片的方法,起先想到的就是通過(guò)WebClient直接去下載當(dāng)前頁(yè)面中引用的驗(yàn)證碼圖片,但繼而想到這會(huì)涉及一些問(wèn)題:一是驗(yàn)證碼可能會(huì)在每次請(qǐng)求時(shí)都發(fā)生變化,二是將WebClient與WebBrowser的Cookies甚至 Session關(guān)聯(lián)起來(lái)是件很難的事。 而后就想到了可以放棄WebBrowser,始終使用WebRequest進(jìn)行較為底層的訪問(wèn),以避免多次獲取驗(yàn)證碼產(chǎn)生變化導(dǎo)致不一致的情況,不過(guò)這種辦法操作起來(lái)還是比較復(fù)雜的。 然后又想到這種變通的方法——抓圖。只需要直接通過(guò)WebBrowser截圖,并將驗(yàn)證碼以外的部分裁剪掉,就可以了。 思路 首先要分析一下那位朋友要獲取的驗(yàn)證圖片元素特征: 網(wǎng)址:http://www./Charge/UCardDirectCharge.aspx?category=AAWYVVWYKV&product=AAWYVVWYKV010CV
這里很簡(jiǎn)單,我們只要找到src屬性為“RandomImage.aspx”結(jié)尾的圖片,就找到我們所需的這個(gè)元素了。 找到這個(gè)元素之后,為了方便確定其位置,并確保其不會(huì)超出WebBrowser可視范圍,我們要為它賦予一個(gè)內(nèi)聯(lián)樣式,使之處于頁(yè)面的絕對(duì)左上角,并設(shè)置z-index為9999,以避免被其他元素覆蓋,這個(gè)樣式即為: "position: absolute; z-index: 9999; top: 0px; left: 0px" 這之后就可以通過(guò)WebBrowser的DrawToBitmap方法截圖了,截圖的寬和高可通過(guò)上述元素的ClientRectangle屬性取得。 實(shí)現(xiàn) 那么現(xiàn)在建立一個(gè)WinForm項(xiàng)目來(lái)做測(cè)試,設(shè)計(jì)如下界面:
然后為按鈕編寫(xiě)事件處理函數(shù):
編譯并運(yùn)行以測(cè)試:
點(diǎn)擊按鈕,稍等片刻,即可在PictureBox中顯示出完整的驗(yàn)證碼圖片了。 提示 WebBrowser 的DrawToBitmap方法是隱藏的,不受智能感知提示支持,我不知道為什么會(huì)這樣,但我知道DrawToBitmap方法確實(shí)存在問(wèn)題,就是截圖出來(lái)全白現(xiàn)象,據(jù)我觀察,發(fā)生這種現(xiàn)象和是否顯示W(wǎng)ebBrowser控件有關(guān),只要在窗體上顯示了WebBrowser控件,截圖出來(lái)就是全白,而如果不將WebBrowser加載到窗體,截圖就是正常的,具體原因不明,只能再次感嘆WebBrowser這個(gè)強(qiáng)大的控件編寫(xiě)的也太粗濫了。 結(jié)語(yǔ) 總的來(lái)說(shuō)WebBrowser截圖還是很有意義的,透過(guò)它可以生成網(wǎng)頁(yè)抓圖,還有此例中演示的對(duì)特定元素抓圖,或者還可以變通地為Flash、XML、Txt之類的任何瀏覽器中可顯示的文件抓圖,在我前一段時(shí)間編寫(xiě)的AWWWB 網(wǎng)站克隆器中,就是使用了這種方式為Flash、Css、JS文件生成預(yù)覽圖的。 出處:http://skyd.cnblogs.com/ |
|
|
來(lái)自: doc360sir > 《webbrowser》