麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > ASP > 正文

為SWFUpload增加ASP版本的上傳處理程序

2024-05-04 11:08:18
字體:
來源:轉載
供稿:網友
SWFUpload上傳組件,最初由Vinterwebb.se開發,組件主體由Flash與JavaScript整合而成,主要致力解決多文件、大文件等的上傳問題,組件提供了豐富的事件與接口方便web開發者調用,開發者可以通過js與css等很方便的控制樣式和實現想要的上傳效果。
 
 
 
但也許是隨著asp的逐漸淡出web開發,官方僅提供了.net、php等版本的上傳處理程序,對于asp開發者來說則需要自行處理服務器端的數據接收。 

剛接觸此組件時就被它功能強大與靈活方便吸引,由于當時項目采用asp開發,百度一番后發現并無好用的asp上傳處理程序(現在有很多啦^^),看來只能自己研究開發啦,最初采用處理普通上傳的方法來截取文件的數據,幾經測試發現并不能有效接收組件傳遞過來的文件數據,無奈只能著手分析下它發送的數據形式,通過分析發現它發送的數據格式還是和普通上傳存在一些區別的,無論是圖片還是文件都是以octet-stream形式發送到服務器的,了解了數據格式,剩下的就是截取啦,下面把我的處理方法分享給需要的朋友,處理速度還算理想。 
復制代碼代碼如下:

<% 
Class SWFUpload 

Private formData, folderPath, streamGet 
Private fileSize, chunkSize, bofCont, eofCont 

REM CLASS-INITIALIZE 

Private Sub Class_Initialize 
Call InitVariant 
Server.ScriptTimeOut = 1800 
Set streamGet = Server.CreateObject("ADODB.Stream") 

sAuthor = "51JS.COM-ZMM" 
sVersion = "Upload Class 1.0" 
End Sub 

REM CLASS-INITIALIZE 

Public Property Let SaveFolder(byVal sFolder) 
If Right(sFolder, 1) = "/" Then 
folderPath = sFolder 
Else 
folderPath = sFolder & "/" 
End If 
End Property 

Public Property Get SaveFolder 
SaveFolder = folderPath 
End Property 

Private Function InitVariant 
chunkSize = 1024 * 128 

folderPath = "/" : fileSize = 1024 * 10 
bofCont = StrToByte("octet-stream" & vbCrlf & vbCrlf) 
eofCont = StrToByte(vbCrlf & String(12, "-")) 
End Function 

Public Function GetUploadData 
Dim curRead : curRead = 0 
Dim dataLen : dataLen = Request.TotalBytes 

streamGet.Type = 1 : streamGet.Open 
Do While curRead < dataLen 
Dim partLen : partLen = chunkSize 
If partLen + curRead > dataLen Then partLen = dataLen - curRead 
streamGet.Write Request.BinaryRead(partLen) 
curRead = curRead + partLen 
Loop 
streamGet.Position = 0 
formData = streamGet.Read(dataLen) 

Call GetUploadFile 
End Function 

Public Function GetUploadFile 
Dim begMark : begMark = StrToByte("filename=") 
Dim begPath : begPath = InStrB(1, formData, begMark & ChrB(34)) + 10 
Dim endPath : endPath = InStrB(begPath, formData, ChrB(34)) 
Dim cntPath : cntPath = MidB(formData, begPath, endPath - begPath) 
Dim cntName : cntName = folderPath & GetClientName(cntPath) 

Dim begFile : begFile = InStrB(1, formData, bofCont) + 15 
Dim endFile : endFile = InStrB(begFile, formData, eofCont) 

Call SaveUploadFile(cntName, begFile, endFile - begFile) 
End Function 

Public Function SaveUploadFile(byVal fName, byVal bCont, byVal sLen) 
Dim filePath : filePath = Server.MapPath(fName) 
If CreateFolder("|", GetParentFolder(filePath)) Then 
streamGet.Position = bCont 
Set streamPut = Server.CreateObject("ADODB.Stream") 
streamPut.Type = 1 : streamPut.Mode = 3 : streamPut.Open 
streamPut.Write streamGet.Read(sLen) 
streamPut.SaveToFile filePath, 2 
streamPut.Close : Set streamPut = Nothing 
End If 
End Function 

Private Function IsNothing(byVal sVar) 
IsNothing = IsNull(sVar) Or (sVar = Empty) 
End Function 

Private Function StrToByte(byVal sText) 
For i = 1 To Len(sText) 
StrToByte = StrToByte & ChrB(Asc(Mid(sText, i, 1))) 
Next 
End Function 

Private Function ByteToStr(byVal sByte) 
Dim streamTmp 
Set streamTmp = Server.CreateObject("ADODB.Stream") 
streamTmp.Type = 2 
streamTmp.Mode = 3 
streamTmp.Open 
streamTmp.WriteText sByte 
streamTmp.Position = 0 
streamTmp.CharSet = "utf-8" 
streamTmp.Position = 2 
ByteToStr = streamTmp.ReadText 
streamTmp.Close 
Set streamTmp = Nothing 
End Function 

Private Function GetClientName(byVal bInfo) 
Dim sInfo, regEx 
sInfo = ByteToStr(bInfo) 
If IsNothing(sInfo) Then 
GetClientName = "" 
Else 
Set regEx = New RegExp 
regEx.Pattern = "^.*//([^//]+)$" 
regEx.Global = False 
regEx.IgnoreCase = True 
GetClientName = regEx.Replace(sInfo, "$1") 
Set regEx = Nothing 
End If 
End Function 

Private Function GetParentFolder(byVal sPath) 
Dim regEx 
Set regEx = New RegExp 
regEx.Pattern = "^(.*)//[^//]*$" 
regEx.Global = True 
regEx.IgnoreCase = True 
GetParentFolder = regEx.Replace(sPath, "$1") 
Set regEx = Nothing 
End Function 

Private Function CreateFolder(byVal sLine, byVal sPath) 
Dim oFso 
Set oFso = Server.CreateObject("Scripting.FileSystemObject") 
If Not oFso.FolderExists(sPath) Then 
Dim regEx 
Set regEx = New RegExp 
regEx.Pattern = "^(.*)//([^//]*)$" 
regEx.Global = False 
regEx.IgnoreCase = True 
sLine = sLine & regEx.Replace(sPath, "$2") & "|" 
sPath = regEx.Replace(sPath, "$1") 
If CreateFolder(sLine, sPath) Then CreateFolder = True 
Set regEx = Nothing 
Else 
If sLine = "|" Then 
CreateFolder = True 
Else 
Dim sTemp : sTemp = Mid(sLine, 2, Len(sLine) - 2) 
If InStrRev(sTemp, "|") = 0 Then 
sLine = "|" 
sPath = sPath & "/" & sTemp 
Else 
Dim Folder : Folder = Mid(sTemp, InStrRev(sTemp, "|") + 1) 
sLine = "|" & Mid(sTemp, 1, InStrRev(sTemp, "|") - 1) & "|" 
sPath = sPath & "/" & Folder 
End If 
oFso.CreateFolder sPath 
If CreateFolder(sLine, sPath) Then CreateFolder = True 
End if 
End If 
Set oFso = Nothing 
End Function 

REM CLASS-TERMINATE 

Private Sub Class_Terminate 
streamGet.Close 
Set streamGet = Nothing 
End Sub 

End Class 

REM 調用方法 
Dim oUpload 
Set oUpload = New SWFUpload 
oUpload.SaveFolder = "存放路徑" 
oUpload.GetUploadData 
Set oUpload = Nothing 
%> 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美69free性videos| 欧美wwwwww| 香蕉久草视频 | 亚洲91网| 男女羞羞视频 | 91丝袜| 日韩电影一区二区 | 久久精品视频7 | 精品三级内地国产在线观看 | 看一级毛片 | 国产精品片一区二区三区 | 国产九九热 | 中文字幕一区在线观看视频 | 精品国产一区二区久久 | chengrenzaixian | 欧美城网站地址 | 91中文在线观看 | 91一区二区在线观看 | 久久网站热最新地址 | 羞羞视频入口 | 黑人日比视频 | 狠狠操电影 | 无码专区aaaaaa免费视频 | 成人做爰s片免费看网站 | 成人毛片100部免费观看 | 国产成人在线看 | 日本黄色一级视频 | 久久久经典视频 | 天天操很很操 | 在线成人免费观看视频 | 欧美日韩在线免费观看 | 午夜丰满少妇高清毛片1000部 | 国产精品久久久久av | 国产精品区一区二区三区 | 91网站在线观看视频 | 国产手机av在线 | 国产精品一区二区x88av | 国产一区二区三区四区五区精品 | 黄色片快播 | 午夜精品福利视频 | 欧美亚洲综合在线 |