" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

批處理 API實現文件下載的代碼

 更新時間:2008年08月29日 19:29:52   投稿:mdxy-dxy  
這篇文檔講述的并不是什么新鮮的技術,我只是起到將他們混和起來實現了自己需要的功能的作用,如果你對批處理和PE格式相當了解,那我的這篇文檔就權且當作瀏覽溫習吧...^_^... 

根據這些,我們可以知道,這個API是在URLMON.DLL文件中的一個導出函數,簡單的實現了把一個文件從WEB服務器下載本機的功能,其實用這個函數還不錯的,至少它幫我們處理了斷點續(xù)傳,緩存等等的功能,比起直接使用SOCKET函數來實現或者用WININET里的函數來實現簡單多得多了.

URLDownloadToFile有五個參數:

第一個參數是僅當調用者是一個ActiveX對象才使用,一般為NULL.

第二個參數就是要下載文件的目標URL,完整路徑.

第三個是本地保存路徑,也是完整路徑

第四個是保留,必須為0

第五個是指向一個IBindStatusCallback接口的指針,這就類似一種回調機制,你可以參考這些來活動當前下載進度,選擇是否繼續(xù)下載等等.

這里面我們只關心第二和第三個參數.其他的通通設置成0.(當然你寫C的時候最好設置為NULL)

嗯,敲了點鍵盤介紹了這個函數,是因為整篇的文檔都和這個函數息息相關,有了這個函數,就可以呼叫RUNDLL32來調用它,但是很可惜,這個美好的計劃馬上也破裂了...

我去微軟看了他們的164787號文檔http://support.microsoft.com/default.aspx?...kb;en-us;164787),該文檔闡述了RUNDLL32的調用方式和能被他調用的函數的格式:

它們是這么說的:


引用

Rundll and Rundll32 programs do not allow you to call any exported function from any DLL. For example, you can not use these utility programs to call the Win32 API (Application Programming Interface) calls exported from the system DLLs. The programs only allow you to call functions from a DLL that are explicitly written to be called by them.



這個是規(guī)定的格式:


代碼

void CALLBACK
EntryPoint(HWND hwnd, HINSTANCE hinst, LPSTR lpszCmdLine, int nCmdShow);



很不幸,我們的URLDownloadToFile小兄弟并沒有符合這些條件,被RUNDLL32無情的拋棄了(汗一滴..)...但是我們并沒有因此而嫌棄它(汗一滴AGAIN..),畢竟,在后來實現的過程里,它是為我們的工作省下了不少功夫.

到此,用RUNDLL32運行計劃流產....(寒...)

想了一根煙功夫,現在URLDownloadToFile有了,怎么才能調用這個函數呢?總不能模仿匯編PUSH 5個參數進棧,然后CALL吧,那這個函數的地址還要用LoadLibrary()和GetProcAddress()計算得來,那這兩個函數的地址.....還是放棄...等等,如果用一個EXE來實現的話就簡單很多了(至少EXE是不需要任何解釋器的),對,寫一個EXE來下載文件.可我們的目的是用BAT來下載呢,BAT文件能包裹EXE的數據嗎?答案是肯定的...往下看..

記得以前看過一篇文檔<<Do All in Cmd Shell>>里面介紹過一種方法.先賣個關子.大家都知道,如果用ECHO加上重定向符來寫文件的話,只能寫入ASCII的一部分,也就可以顯示出來的那些ASCII(也就是ASCII值小于128的那些),對于那些無法顯示的字符就沒有辦法了.但是這讓我們想起一個工具,一個微軟歷史上同樣古老的,批處理的兄弟--DEBUG!

現在思路清晰了:可以讓批處理把ECHO不能顯示的字符轉化為16進制數據(比如EXE中的那些數據)保存在批處理中,然后用DEBUG寫道文件里,最后用BAT調用生成的EXE,下載文件!(想完了這里,我感覺還是太麻煩,不知道哪位牛人對這個實現還有什么更加簡單的辦法嗎??)


四.解決-實戰(zhàn)

倘若就此編寫一個可下載文件的EXE,然后直接用BAT包裹,定然會被同行恥笑,不單是因為那幾千個字節(jié)的數據拖著大大臃腫的BAT文件,更加讓為這種簡單的想法立刻現形,為了不達到這些負面效果,也為了讓這篇文檔不至于干癟癟的讓人感覺沒什么看頭(事實上是因為早些時候看過watercloud的一篇大作感悟頗深),我決定手工寫一串16進制代碼來代替機器編譯的EXE.既美觀了界面,又增強了技術性.....(一_一...簡直是在賣作...)

現在當務之急是要一個可以下載文件的EXE程序,實現這個目標只要一個URLDownloadToFile即可,放在最后實現,先來寫一個PE框架:大家都知道PE文件的格式吧,不懂的就去看看那個著名的電信黑客羅某某的書.(Who!?...~)

先給出我們的PE框架,基于XP的FileAlignment對齊大小最小就支持到0x200(也就是10進制的512字節(jié),以下有在前面加上0x的都表示16進制數值),我們的框架就打出512字節(jié)(注意,我下面留有空白表示各個PE部分,結合下面的文檔,大家方便理解),這個框架里沒有任何的代碼或者數據:

(ZV友情提示:下面是最枯燥的部分,各位手握錐子,要有一不怕苦,二不怕痛的精神看完它....)
(如果定力不高的朋友,或者堆PE文件再熟悉不過的朋友,可以字節(jié)轉到"JMP S1"處往下看.)
(如果只想知道到底怎么回事,或者對這篇作文報瀏覽態(tài)度的朋友,可以直接轉到"JMP S2"處繼續(xù)瀏覽)
(睡著了的繼續(xù)睡覺....)

相關文章

最新評論