当前位置: 移动技术网 > IT编程>开发语言>Asp > Asp下实现多表单域无组件文件上传的实例

Asp下实现多表单域无组件文件上传的实例

2017年12月12日  | 移动技术网IT编程  | 我要评论
最近经常有人问到这类问题,在此转贴一下,内容:
1。数据库表结构(access):
userid:text(保存上传文件的用户id)
filecontenttype:text(用来保存上传文件的类型,eg:"application/msword",主要用来使用户能正确下载此文件)
filecontent:ole object(保存文件数据)

2。html文件
muploadfile.htm
<form name="upload_file" enctype="multipart/form-data" action="muploadfile.asp" method=post>
<input type=hidden name="userid" value="abc">
<input type=hidden name="fileuploadstart"> '这里用来表示开始文件数据上传
file to send: 

<input type="file" name="file_up" size="30"><br>
<input type="file" name="file_up" size="30"><br>
<input type=hidden name="fileuploadend"> '这里用来表示文件数据结束
<input type=submit value=submit>
</form></p><p>
3。asp文件
muploadfile.asp</p><p><%
response.expires=0
function bin2str(binstr) 
    dim varlen,clow,ccc,skipflag </p><p>    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 </p><p>
varbytecount = request.totalbytes
bncrlf = chrb( 13 ) & chrb( 10 )
binhttpheader=request.binaryread(varbytecount)        
divider = leftb( binhttpheader,  instrb( binhttpheader, bncrlf ) - 1 )</p><p>'开始读非文件域的数据
do while lenb(binhttpheader)>46

    binheaderdata = leftb(binhttpheader, instrb( binhttpheader, bncrlf & bncrlf )-1)
    strheaderdata=bin2str(binheaderdata)</p><p>    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</p><p>    binfieldvalue=midb( binhttpheader, datastart, dataend )
    strfieldvalue=bin2str(binfieldvalue)
    strfieldvalue=trim(strfieldvalue)
    strfieldvalue=replace(strfieldvalue,vbcrlf,vbnullstring)</p><p>    '非文件上传域变量赋值
    execute strfieldname&"="""&strfieldvalue&""""

        
    binhttpheader=midb(binhttpheader,instrb( datastart + 1, binhttpheader, divider ))

loop</p><p>'开始处理文件数据
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")</p><p>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")</p><p>lngoffset=0
conchunksize=1024
lngpictsize=rs("filecontent").actualsize
do while lngoffset < lngpictsize
  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
%></p><p>就是这些了,希望此方法对大家能有所帮助。:)

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网