首页 数据库 mysql教程 无组件文件上传代码实例

无组件文件上传代码实例

Jun 07, 2016 pm 03:16 PM
上传 代码 关于 实例 文件 文章 组件

关于无组件文件上传的文章已经很多了,所以在这里我不想再解释无组件文件上传的原理。在asp中无法将二进制文件数据直接保存成文件,所以我们一般还是利用数据库来保存用户上传的文件。 1。数据库表结构(access): UserID:Text(保存上传文件的用户ID) FileCon

关于无组件文件上传的文章已经很多了,所以在这里我不想再解释无组件文件上传的原理。在asp中无法将二进制文件数据直接保存成文件,所以我们一般还是利用数据库来保存用户上传的文件。

1。数据库表结构(access):
UserID:Text(保存上传文件的用户ID)
FileContentType:Text(用来保存上传文件的类型,eg:"application/msWord",主要用来使用户能正确下载此文件)
FileContent:OLE Object(保存文件数据)

2。HTML文件
muploadfile.htm


'这里用来表示开始文件数据上传
File to send:





'这里用来表示文件数据结束



3。ASP文件
muploadfile.asp

Response.Expires=0
Function bin2str(binstr)
  Dim varlen,clow,ccc,skipflag

  skipflag=0
  ccc = ""
  If Not IsNull(binstr) Then
    varlen=LenB(binstr)
    For i=1 To varlen
      If skipflag=0 Then
        clow = MidB(binstr,i,1)
        If AscB(clow) > 127 Then
          ccc =ccc & Chr(AscW(MidB(binstr,i+1,1) & clow))
          skipflag=1
        Else
          ccc = ccc & Chr(AscB(clow))
        End If
      Else
        skipflag=0
      End If
    Next
  End If
  bin2str = ccc
End Function


varByteCount = Request.TotalBytes
bnCRLF = chrB( 13 ) & chrB( 10 )
binHTTPHeader=Request.BinaryRead(varByteCount)    
Divider = LEFTB( binHTTPHeader, INSTRB( binHTTPHeader, bnCRLF ) - 1 )

'开始读非文件域的数据
Do while lenB(binHTTPHeader)>46
  
  binHeaderData = LeftB(binHTTPHeader, INSTRB( binHTTPHeader, bnCRLF & bnCRLF )-1)
  strHeaderData=bin2str(binHeaderData)

  lngFieldNameStart=Instr(strHeaderData,"name="&chr(34))+Len("name="&chr(34))
  lngFieldNameEnd=Instr(lngFieldNameStart,strHeaderData,chr(34))
  
  
  strFieldName=Mid(strHeaderData,lngFieldNameStart,lngFieldNameEnd-lngFieldNameStart)
  strFieldName=Trim(strFieldName)
  strFieldName=Replace(strFieldName,vbcrlf,vbnullstring)
  
    '判断文件数据时候开始
  If strComp(strFieldName,"FileUploadStart",1)=0 Then
    binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
    exit do
  End if
  
  DataStart = INSTRB( binHTTPHeader, bnCRLF & bnCRLF ) + 4
  DataEnd = INSTRB( DataStart + 1, binHTTPHeader, divider ) - DataStart

  binFieldValue=MIDB( binHTTPHeader, DataStart, DataEnd )
  strFieldValue=bin2str(binFieldValue)
  strFieldValue=Trim(strFieldValue)
  strFieldValue=Replace(strFieldValue,vbcrlf,vbnullstring)

  '非文件上传域变量赋值
  execute strFieldName&"="""&strFieldValue&""""
  
    
  binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
    
loop

'开始处理文件数据
Do while lenB(binHTTPHeader)>46
  
  
  binHeaderData = LeftB(binHTTPHeader, INSTRB( binHTTPHeader, bnCRLF & bnCRLF )-1)
    
  strHeaderData=bin2str(binHeaderData)
  
  '读取上传文件的Content-Type
  lngFileContentTypeStart=Instr(strHeaderData,"Content-Type:")+Len("Content-Type:")
  strFileContentType=Trim(Mid(strHeaderData,lngFileContentTypeStart))
  strFileContentType=Replace(strFileContentType,vbCRLF,vbNullString)
  
  '读取上传的文件名
  lngFileNameStart=Instr(strHeaderData,"filename="&chr(34))+Len("filename="&chr(34))
  lngFileNameEnd=Instr(lngFileNameStart,strHeaderData,chr(34))
  strFileName=Mid(strHeaderData,lngFileNameStart,lngFileNameEnd-lngFileNameStart)
  strFileName=Trim(strFileName)
  strFileName=Replace(strFileName,vbCRLF,vbNullString)
  
  '读取上传文件数据
  DataStart = INSTRB( binHTTPHeader, bnCRLF & bnCRLF ) + 4
  DataEnd = INSTRB( DataStart + 1, binHTTPHeader, divider ) - DataStart
  
  If strFileName"" Then
        
    binFieldValue=MIDB( binHTTPHeader, DataStart, DataEnd )
    
    '将上传的文件写入数据库
    set conn = Server.CreateObject("ADODB.Connection")
    conn.Open "DSN=abc"
    
    SQL="select * from User_File"
    set rs=server.CreateObject("ADODB.Recordset")
    rs.Open sql,conn,3,3
    rs.addnew
    rs("UserID")=UserID
    rs("FileContentType")=strFileContentType
    rs("FileContent").AppendChunk binFieldValue
    rs.update
    rs.close
    set rs=Nothing
    conn.Close
    set conn=Nothing
    
  End if
  
  binHTTPHeader=MIDB(binHTTPHeader,INSTRB( DataStart + 1, binHTTPHeader, divider ))
  
loop
%>

4。下载用户上传的文件
Response.Buffer   = true
Response.Clear

UserID=request("UserID")

Set conn=server.createobject("adodb.connection")
set rs=server.createobject("adodb.recordset")
conn.open "DSN=UploadFile"
rs.open "select * from User_File where UserID='"&UserID&"'",conn,3,3
Response.ContentType = rs("FileContentType")

lngOffset=0
conChunkSize=1024
lngPictSize=rs("FileContent").ActualSize
Do While lngOffset  varChunk = rs("FileContent").GetChunk(conChunkSize)
 Response.BinaryWrite varChunk
 lngOffset = lngOffset + conChunkSize
 If lngOffset > lngPictSize Then Exit Do
Loop

rs.close
set rs=Nothing
conn.close
set conn=nothing
%>

就是这些了,希望此方法对大家能有所帮助。:)

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

出现0x80004005错误代码怎么办 小编教你0x80004005错误代码解决方法 出现0x80004005错误代码怎么办 小编教你0x80004005错误代码解决方法 Mar 21, 2024 pm 09:17 PM

在电脑中删除或解压缩文件夹,时有时候会弹出提示对话框“错误0x80004005:未指定错误”,如果遇到这中情况应该怎么解决呢?提示错误代码0x80004005的原因其实有很多,但大部分因为病毒导致,我们可以重新注册dll来解决问题,下面,小编给大伙讲解0x80004005错误代码处理经验。有用户在使用电脑时出现错误代码0X80004005的提示,0x80004005错误主要是由于计算机没有正确注册某些动态链接库文件,或者计算机与Internet之间存在不允许的HTTPS连接防火墙所引起。那么如何

夸克网盘的文件怎么转移到百度网盘? 夸克网盘的文件怎么转移到百度网盘? Mar 14, 2024 pm 02:07 PM

  夸克网盘和百度网盘都是现在最常用的储存文件的网盘软件,如果想要将夸克网盘内的文件保存到百度网盘,要怎么操作呢?本期小编整理了夸克网盘电脑端的文件转移到百度网盘的教程步骤,一起来看看是怎么操作吧。  夸克网盘的文件怎么保存到百度网盘?要将夸克网盘的文件转移到百度网盘,首先需在夸克网盘下载所需文件,然后在百度网盘客户端中选择目标文件夹并打开。接着,将夸克网盘中下载的文件拖放到百度网盘客户端打开的文件夹中,或者使用上传功能将文件添加至百度网盘。确保上传完成后在百度网盘中查看文件是否成功转移。这样就

今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法! 今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法! Mar 15, 2024 pm 04:13 PM

一、今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法!1.开通基础权益:原创文章选择投放广告可获得收益,视频必须要原创横屏才会有收益。2.开通百粉权益:粉丝量达到百粉以上,微头条、原创问答创作及问答均可获得收益。3.坚持原创作品:原创作品包含文章、微头条及问题等,要求300字以上。注意违规抄袭作品作为原创发布,会被扣信用分,即使有收益也会被扣除。4.垂直度:做专业领域一类的文章,不能随意跨领域写文章,会得不到合适的推荐,达不到作品的专和精,难以吸引粉丝读者。5.活跃度:活跃度高,

hiberfil.sys是什么文件?hiberfil.sys可以删除吗? hiberfil.sys是什么文件?hiberfil.sys可以删除吗? Mar 15, 2024 am 09:49 AM

  最近有很多网友问小编,hiberfil.sys是什么文件?hiberfil.sys占用了大量的C盘空间可以删除吗?小编可以告诉大家hiberfil.sys文件是可以删除的。下面就来看看详细的内容。hiberfil.sys是Windows系统中的一个隐藏文件,也是系统休眠文件。通常存储在C盘根目录下,其大小与系统安装内存大小相当。这个文件在计算机休眠时被使用,其中包含了当前系统的内存数据,以便在恢复时快速恢复到之前的状态。由于其大小与内存容量相等,因此它可能会占用较大的硬盘空间。  hiber

酷狗上传自己的音乐的简单步骤 酷狗上传自己的音乐的简单步骤 Mar 25, 2024 pm 10:56 PM

1、打开酷狗音乐,点击个人头像。2、点击右上角设置的图标。3、点击【上传音乐作品】。4、点击【上传作品】。5、选择歌曲,然后点击【下一步】。6、最后点击【上传】即可。

GE通用远程代码可在任何设备上编程 GE通用远程代码可在任何设备上编程 Mar 02, 2024 pm 01:58 PM

如果您需要远程编程任何设备,这篇文章会给您带来帮助。我们将分享编程任何设备的顶级GE通用远程代码。通用电气的遥控器是什么?GEUniversalRemote是一款遥控器,可用于控制多个设备,如智能电视、LG、Vizio、索尼、蓝光、DVD、DVR、Roku、AppleTV、流媒体播放器等。GEUniversal遥控器有各种型号,具有不同的功能和功能。GEUniversalRemote最多可以控制四台设备。顶级通用遥控器代码,可在任何设备上编程GE遥控器配备一组代码,使其能够与不同设备相配合。您可

MySQL中.ibd文件的作用详解及相关注意事项 MySQL中.ibd文件的作用详解及相关注意事项 Mar 15, 2024 am 08:00 AM

MySQL中.ibd文件的作用详解及相关注意事项MySQL是一种流行的关系型数据库管理系统,数据库中的数据存储在不同的文件中。其中,.ibd文件是InnoDB存储引擎中的数据文件,用于存储表中的数据和索引。本文将对MySQL中.ibd文件的作用进行详细解析,并提供相关代码示例以帮助读者更好地理解。一、.ibd文件的作用:存储数据:.ibd文件是InnoDB存

如何使用Copilot生成代码 如何使用Copilot生成代码 Mar 23, 2024 am 10:41 AM

作为一名程序员,对于能够简化编码体验的工具,我感到非常兴奋。借助人工智能工具的帮助,我们可以生成演示代码,并根据需求进行必要的修改。在VisualStudioCode中新引入的Copilot工具让我们能够创建具有自然语言聊天交互的AI生成代码。通过解释功能,我们可以更好地理解现有代码的含义。如何使用Copilot生成代码?要开始,我们首先需要获得最新的PowerPlatformTools扩展。要实现这一点,你需要进入扩展页面,搜索“PowerPlatformTool”,然后点击Install按钮

See all articles