好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 為SWFUpload增加ASP版本的上傳處理程序

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

熱門標簽:地圖標注陽江 梧州市地圖標注 世界地圖標注了哪些城市 java外呼系統是什么 石家莊慧營銷外呼系統 武穴地圖標注 創意電話機器人 外呼線路批發 濟源電銷外呼系統線路
但也許是隨著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
%>
您可能感興趣的文章:
  • 使用SWFUpload實現無刷新上傳圖片
  • PHP swfupload圖片上傳的實例代碼
  • SwfUpload在IE10上不出現上傳按鈕的解決方法
  • swfupload ajax無刷新上傳圖片實例代碼
  • phpcms模塊開發之swfupload的使用介紹
  • SWFUpload與CI不能正確上傳識別文件MIME類型解決方法分享
  • swfupload 多文件上傳實現代碼
  • swfupload使用代碼說明
  • 文件上傳之SWFUpload插件(代碼)
  • 文件上傳插件SWFUpload的使用指南

標簽:南寧 淮北 揭陽 唐山 滁州 來賓 迪慶 甘南

巨人網絡通訊聲明:本文標題《為SWFUpload增加ASP版本的上傳處理程序》,本文關鍵詞  為,SWFUpload,增加,ASP,版本,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《為SWFUpload增加ASP版本的上傳處理程序》相關的同類信息!
  • 本頁收集關于為SWFUpload增加ASP版本的上傳處理程序的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 久久国产精品国产精品| 欧美大片全黄在线观看| 男男黄色片| 国产成人精品免费观看| 精品久久免费一区二区三区四区| 中文字幕亚洲欧美一区| 男男调教军警奴跪下抽打| 中文字幕av久久波多野结| 韩国女主播| 中国成人免费视频| 老熟九色91popny| 美女黄色大全| 脱了护士吃奶电影网站| 99热这里只有免费国产精品| 亚洲欧美日韩国产综合高清| 男人边吃奶边做边爱动态图片| 欧美视频一区二区三区| jizz性欧美3| 白痰多可能预示三种病| 东北小伙gay巨大xxxⅹ| 震车婬荡的秘书呻吟h| ??国产精品海角社区| 忘忧草日本在线| 免费国产成人α片| 真实国产乱子伦在线视频不卡| 強姦?乱暴を強いられる| 在线观看免费成人| 啪啪影视大全| 国产精品久久久久999| 古风一女N男到处做高H| 女女百合舌伸腿间湿润动漫| 粉红理论未删减| 欧美人交性视频在线香蕉| 午夜Av旡码国产高清蜜月| 一级黄色大片免费看| 91蝌蚪91????九色| 中中文字幕亚州无线码| 总攻一攻n受肉多(H)| 操白丝美女| 国产精品一区电影| 爆?喷水?洗澡?AI|