• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • ASP無組件上傳進度條解決方案

    發表于:2007-07-14來源:作者:點擊數: 標簽:
    一、無組件上傳的原理 我還是一點一點用一個實例來說明的吧,客戶端HTML如下。要瀏覽上傳附件,我們通過<input type="file">元素,但是一定要注意必須設置form的enctype屬性為"multipart/form-data": <form method="post" action="upload.asp" enctype="

    一、無組件上傳的原理

    我還是一點一點用一個實例來說明的吧,客戶端HTML如下。要瀏覽上傳附件,我們通過<input type="file">元素,但是一定要注意必須設置form的enctype屬性為"multipart/form-data":

    <form method="post" action="upload.asp" enctype="multipart/form-data"> <br> <label> <br> <input type="file" name="file1" /> <br> </label> <br> <br /> <br> <input type="text" name="filename" value="default filename"/> <br> <br /> <input type="submit" value="Submit"/> <br> <input type="reset" value="Reset"/> <br> </form>

    后臺asp程序中,以前獲取表單提交的ASCII 數據,非常的容易。但是如果需要獲取上傳的文件,就必須使用Request對象的BinaryRead方法來讀取。BinaryRead方法是對當前輸入流進行指定字節數的二進制讀取,有點需要注意的是,一旦使用BinaryRead 方法后,再也不能使用Request.Form 或 Request.QueryString 集合了。結合Request對象的TotalBytes屬性,可以將所有表單提交的數據全部變成二進制,不過這些數據都是經過編碼的。首先讓我們來看看這些數據是如何編碼的,有無什么規律可循,編段代碼,在代碼中我們將BinaryRead讀取的二進制轉化為文本,輸出出來,在后臺的upload.asp中(注意該示例不要上傳大文件,否則可能會造成瀏覽器死掉):

    <%Dim biData, PostDataSize = Request.TotalBytesbiData = Request.BinaryRead(Size)PostData = BinaryToString(biData,Size)Response.Write " <pre> " & PostData & " </pre> "
    '使用pre,原樣輸出格式
    ' 借助RecordSet將二進制流轉化成文本
    Function BinaryToString(biData,Size) Const adLongVarChar = 201 Set RS = CreateObject("ADODB.Recordset") RS.Fields.Append "mBinary", adLongVarChar, Size RS.Open RS.AddNew RS("mBinary").AppendChunk(biData) RS.Update BinaryToString = RS("mBinary").Value RS.CloseEnd Function %>
    簡單起見,上傳一個最簡單的文本文件(G:\homepage.txt,內容為"寶玉:http://www.webuc.net")來試驗一下,文本框filename中保留默認值"default filename",提交看看輸出結果:
    -----------------------------

    7d429871607feContent-Disposition: form-data; name="file1"; filename="G:\homepage.txt"Content-Type: text/plain寶玉:    http://www.webuc.net
    -----------------------------
    7d429871607feContent-Disposition: form-data; name="filename"default filename
    -----------------------------
    7d429871607fe--
    可以看出來對于表單中的項目,是用過"-----------------------------7d429871607fe"這樣的邊界來分隔成一塊一塊的,每一塊的開始都有一些描述信息,例如:Content-Disposition: form-data; name="filename",在描述信息中,通過name="filename"可以知道表單項的name。如果有filename="G:\homepage.txt"這樣的內容,說明是一個上傳的文件,如果是一個上傳的文件,那么描述信息會多一行Content-Type: text/plain來描述文件的Content-Type。描述信息和主體信息之間是通過換行來分隔的。

    基本上清晰了,根據這個規律我們就知道該怎么來分離數據,再對分離的數據進行處理了,不過差點忽略一個問題,就是邊界值(上例中的"-----------------------------7d429871607fe")是怎么知道的?每次上傳這個邊界值是不一樣的,還好還好asp中可以通過Request.ServerVariables( "HTTP_CONTENT_TYPE")來獲之,例如上例中HTTP_CONTENT_TYPE內容為:"multipart/form-data; boundary=---------------------------7d429871607fe",有了這個,我們不僅可以判斷客戶端的form中有無使用enctype="multipart/form-data"(如果沒有使用,那么下面就沒必要執行啦),還可以獲取邊界值boundary=---------------------------7d429871607fe。(注意:這里獲取的邊界值比上面的邊界值開頭要少"--",最好補充上。)

    本新聞共3頁,當前在第1頁  1  2  3  

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>