上传文件到数据库,如何获得文件名

sq0421 2003-10-24 10:30:19
==================浏览文件的代码=============
<form enctype="multipart/form-data" action="addfile.asp" method=post onsubmit="return mysubmit(this)">
<input name="big" type="file" class="button" size="20">
<input name="B3" type="submit" class="button" value="上传">
</form>

==============addfile.asp==================
<!--#include file="../function/conn.inc"-->
<%
dim rs
dim formsize,formdata,bncrlf,divider,datastart,dataend,mydata
formsize=request.totalbytes
formdata=request.binaryread(formsize)
bncrlf=chrB(13) & chrB(10)
divider=leftB(formdata,clng(instrb(formdata,bncrlf))-1)
datastart=instrb(formdata,bncrlf & bncrlf)+4
dataend=instrb(datastart+1,formdata,divider)-datastart
mydata=midb(formdata,datastart,dataend)

Set rs = Server.CreateObject("ADODB.Recordset")
rs.Open "files",conn,3,2
rs.addnew
rs("file_content").appendchunk mydata
rs("test_id")=session("test_id")
rs.update
set rs=nothing
set conn=nothing
session("test_id")=""
response.write "<script>alert('添加成功!');MM_goToURL('self','project_test.asp');</script>"
response.end
%>
==========================================
如果获得上传文件的文件名???
...全文
83 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
uibe 2003-10-30
  • 打赏
  • 举报
回复
adfasfsafa
zjcxc 2003-10-29
  • 打赏
  • 举报
回复
你可以到下面的贴子获取更多的内容
http://expert.csdn.net/Expert/topic/2403/2403509.xml?temp=.3477442
zjcxc 2003-10-29
  • 打赏
  • 举报
回复
下面的代码分析出了上传的文件名,文件类型,及文件内容
'==================================================================
'
' 上传文件保存到数据库的ASP页: zj_up.asp
'
'==================================================================
<%
Response.Expires=0
Function f_Bin2Str(ByVal sBin)
Dim iI, iLen, iChr, iRe
iRe = ""
If Not IsNull(sBin) Then
iLen = LenB(sBin)
For iI = 1 To iLen
iChr = MidB(sBin, iI, 1)
If AscB(iChr) > 127 Then
iRe = iRe & Chr(AscW(MidB(sBin, iI + 1, 1) & iChr))
iI = iI + 1
Else
iRe = iRe & Chr(AscB(iChr))
End If
Next
End If
f_Bin2Str = iRe
End Function
iConcStr = "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False" & _
";Data Source=" & server.mappath("zj.mdb")
iSql="tb_img"
set iRe=Server.CreateObject("ADODB.Recordset")
iRe.Open iSql,iConcStr,1,3
iLen=Request.TotalBytes
sBin=Request.BinaryRead(iLen)
iCrlf1 = ChrB(13) & ChrB(10)
iCrlf2 = iCrlf1 & iCrlf1
iLen = InStrB(1, sBin, iCrlf1) - 1
iSpc = LeftB(sBin, iLen)
sBin = MidB(sBin, iLen + 34)
iPos1 = InStrB(sBin, iCrlf2) - 1
While iPos1 > 0
iStr = f_Bin2Str(LeftB(sBin, iPos1))
iPos1 = iPos1 + 5
iPos2 = InStrB(iPos1, sBin, iSpc)

iPos3 = InStr(iStr, "; filename=""") + 12
If iPos3 > 12 Then
iStr = Mid(iStr, iPos3)
iPos3 = InStr(iStr, Chr(13) & Chr(10) & "Content-Type: ") - 2
iFn = Left(iStr, iPos3)
If iFn <> "" Then
iRe.AddNew
ire("path")=left(iFn,instrrev(iFn,"\"))
iRe("fname") = mid(iFn,instrrev(iFn,"\")+1)
iRe("type") = Mid(iStr, iPos3 + 18)
iRe("img").AppendChunk MidB(sBin, iPos1, iPos2 - iPos1)
iRe.Update
End If
End If

sBin = MidB(sBin, iPos2 + iLen + 34)
iPos1 = InStrB(sBin, iCrlf2) - 1
Wend
iRe.close
set iRe=Nothing
%>

'==================================================================
sq0421 2003-10-29
  • 打赏
  • 举报
回复
up....
sq0421 2003-10-24
  • 打赏
  • 举报
回复
Equn(熠群)你的说法如何实现?
sq0421 2003-10-24
  • 打赏
  • 举报
回复
用javascript传递不过来,可能是enctype="multipart/form-data"的问题
lovehwq21 2003-10-24
  • 打赏
  • 举报
回复
你这个已经是一个处理页面的,你应该在前一个页面拿取文件名,然后传过来
Equn 2003-10-24
  • 打赏
  • 举报
回复
查找formdata中的filename=后面的值
lovehwq21 2003-10-24
  • 打赏
  • 举报
回复
呵呵……
这么麻烦啊,帮你顶一下
sq0421 2003-10-24
  • 打赏
  • 举报
回复
各位,给点干的吧...

28,391

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧