为SWFUpload增加ASP版本的上传处理程序

但也许是随着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

%>

时间: 2024-09-20 21:37:41

为SWFUpload增加ASP版本的上传处理程序的相关文章

为SWFUpload增加ASP版本的上传处理程序_应用技巧

但也许是随着asp的逐渐淡出web开发,官方仅提供了.net.php等版本的上传处理程序,对于asp开发者来说则需要自行处理服务器端的数据接收. 刚接触此组件时就被它功能强大与灵活方便吸引,由于当时项目采用asp开发,百度一番后发现并无好用的asp上传处理程序(现在有很多啦^^),看来只能自己研究开发啦,最初采用处理普通上传的方法来截取文件的数据,几经测试发现并不能有效接收组件传递过来的文件数据,无奈只能着手分析下它发送的数据形式,通过分析发现它发送的数据格式还是和普通上传存在一些区别的,无论是

ASP跨服务器上传文件完美解决

服务器|解决|上传 如果你有两个空间,一个大而慢,另外一个小而快,或者其中一个不支持FSO,那么跨服务器上传文件这个问题就摆在你面前了,下面就是我在解决ylog.net里面的跨服务器上传文件的日记,这个问题看似简单,里面的细节问题却是非常有趣 前提条件,空间都必须支持ASP,上传文件的服务器支持FSO,下面的叙述中,diygame.com为存上传文件的服务器,ylog.net为网站服务器,即显示用户界面的服务器... 实现功能,文件上传,上传后在网页的文本区域自动加上对于图片的UBB码,为了清楚

Asp.net文件上传操作

asp.net|上传 在ASP里要上传一个文件是很麻烦的事,需要稻香老农之类的组件的支持.在ASP.Net事情就变得简单了许多.如下面上传图片的例子.首先申明使用命名空间.using System.IO;在设计页面拖进一个input(File)控件,并把它作为服务器控件运行.其ID为myFile:然后拖进一个button,给button的单击时间添加如下代码: protected void submit_Click(object sender, EventArgs e)    {        

asp.net文件上传示例

 ASP.NET依托.net framework类库,封装了大量的功能,使得上传文件非常简单,主要有以下三种基本方法,需要的朋友可以参考下 方法一:用Web控件FileUpload,上传到网站根目录.   Test.aspx关键代码:    代码如下: <form id="form1" runat="server"> <asp:FileUpload ID="FileUpload1" runat="server"

asp.net 文件上传实例汇总

 文件上传在asp.net中有很多方法,这里我很给各位介绍最简单最方便的.net文件上传实例,希望给各位.net入门者带来帮助 ASP.NET依托.net framework类库,封装了大量的功能,使得上传文件非常简单,主要有以下三种基本方法.   方法一:用Web控件FileUpload,上传到网站根目录.   Test.aspx关键代码:    代码如下:      <form id="form1" runat="server">      <

Asp.Net + Flash 上传的组件,文件上传后返回值问题,急!

问题描述 我从网上下载了一个Asp.Net+Flash上传的组件,自己改了下,现在已实现以下功能: 1.上传多个文件: 2.定义上传各种类型的文件: 3.定义上传路径: 4.支持上传大文件. 主页面:Default.aspx(页面链接包含了:Default.aspx.cs.upload.swf.UploadVideo.ashx) 上传文件页面:UploadVideo.ashx 现在有个很大的问题:就是UploadVideo.ashx页面上传文件后,要如何将文件名称(处理结果)返回到Default

asp.net文件上传示例分享_实用技巧

方法一:用Web控件FileUpload,上传到网站根目录. Test.aspx关键代码: 复制代码 代码如下: <form id="form1" runat="server"><asp:FileUpload ID="FileUpload1" runat="server" /><asp:Button ID="Button1" runat="server" T

asp.net 文件上传实例汇总_实用技巧

ASP.NET依托.net framework类库,封装了大量的功能,使得上传文件非常简单,主要有以下三种基本方法. 方法一:用Web控件FileUpload,上传到网站根目录. Test.aspx关键代码: 复制代码 代码如下:      <form id="form1" runat="server">     <asp:FileUpload ID="FileUpload1" runat="server"

asp.net 文件上传示例整理

ASP.NET依托.net framework类库,封装了大量的功能,使得上传文件非常简单,主要有以下三种基本方法. 方法一:用Web控件FileUpload,上传到网站根目录.  代码如下 复制代码 Test.aspx关键代码:        <form id="form1" runat="server">      <asp:FileUpload ID="FileUpload1" runat="server&quo