亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

多圖片上傳到指定的目錄并存到數據庫

2019-11-18 20:16:07
字體:
來源:轉載
供稿:網友
關于圖片上傳的例子在網上有很多文章和原代碼。但是每次上論壇瀏覽帖子的時候都是看到很多網友對圖片上傳感到頭疼和麻煩。其實這個問題也是曾經讓我感到頭疼。也看過了不少的文章和代碼?,F在我寫的這篇文章是把我比較喜歡的一篇代碼和動網里的高手對這篇代碼優化后再加上我增加一些代碼結合出來的!呵呵,其實這篇文章是沾了寫這篇代碼的人(稻香居士)和動網里那些高手的光。:)
好了,不說廢話了。開始來搭建所需要的環境和數據結構!
先新建一個名字叫photo的文件夾。(我在這里就是把圖片上傳到這個文件夾里的。)建立一個名字叫database的數據庫。再接著建立一個名字叫sFile的表。表里設計四個字段分別是id(int),image(varchar),image1(varchar),image2(varchar)。我這里用的數據庫是SQL。
相關的文件
register.asp
<html>
<head>
<title>文件</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<form name="form1" method="post" action="save.asp">
  <table width="50%" border="1" cellspacing="0" cellpadding="0" align="center">
    <tr>
      <td width="20%"><a href="#"  OnClick="javascr      <td width="80%">   
        <input type="text" name="myface">
          
        <input type="text" name="myface1">
          
        <input type="text" name="myface2">
        (此處用戶不必填圖片上傳后自動生成) </td>
    </tr>
    <tr>
      <td colspan="2"  align="center">
        <input type="submit" name="Submit" value="提交">
        <input type="reset" name="Submit2" value="重設">
      </td>
    </tr>
  </table>
</form>
</body>
</html>

reg_upload.asp
<html>
<head>
<title></title>
<meta http-equiv="Content-Type"  content="text/html; charset=gb2312">
<link rel="stylesheet" href="
CSS/style.css" type="text/css">
</head>
<body leftmargin="0" topmargin="0"   >
  <br>
<br>
<br>
<table width="90%" border="0" align="center" bgcolor="#000000" height="152" cellspacing="1">
  <tr>
    <td height="34" align="center" bgcolor="#FFFFFF"><font color="#FFFF33"><b><font size="4" color="#000000">選擇圖片</font></b></font></td>
  </tr>
  <tr>
    <td bgcolor="#FFFFFF">
      <form name="form"  method="post" action="upfile.asp" enctype="multipart/form-data" >
        <input type="hidden" name="filepath" value="photo">
        <input type="hidden"  name="act" value="upload">
        <input type="file" name="file1"  size="30"><br>
         <input type="file" name="file2" size="30"><br>
         <input type="file" name="file3" size="30">
           
        <input  type="submit" name="Submit" value="粘 貼" class="tl">
      </form>
    </td>
  </tr>
</table>
</body>
</html>

upfile.asp
<!--#include FILE="upload.inc"-->
<html>
<head>
<title>文件上傳</title>
</head>
<body>
<%
dim arr(3)
dim upload,file,formName,formPath,iCount,filename,fileExt,i
set upload=new upload_5xSoft ''建立上傳對象


formPath=upload.form("filepath")
''在目錄后加(/)
if right(formPath,1)<>"/" then formPath=formPath&"/"
iCount=0
i=0
for each formName in upload.file ''列出所有上傳了的文件
    set file=upload.file(formName)  ''生成一個文件對象
   
    if file.filesize<0 then
        response.write "<font size=2>請先選擇你要上傳的圖片 [ <a href=# onclick=history.go(-1)>重新上傳</a> ]</font>"
        response.end
    end if
   
    if file.filesize>100000 then
        response.write "<font size=2>圖片大小超過了限制 [ <a href=# onclick=history.go(-1)>重新上傳</a> ]</font>"
        response.end
    end if
if fileEXT<>".gif" and fileEXT<>".jpg" then
     response.write "<font size=2>文件格式不對 [ <a href=# onclick=history.go(-1)>重新上傳</a> ]</font>"
    response.end
end if

    fileExt=lcase(right(file.filename,4))
    filename=formPath&year(now)&month(now)&day(now)&hour(now)&minute(now)&second(now)&file.FileName
    arr(i)=filename
    i=i+1

    if file.FileSize>0 then         ''如果 FileSize > 0 說明有文件數據
        file.SaveAs Server.mappath(filename)   ''保存文件
        ' response.write file.FilePath&file.FileName&" ("&file.FileSize&") => "&formPath&File.FileName&" 成功!<br>"

          iCount=iCount+1
    end if
    set file=nothing
next
if instr(arr(0),".")=0 and instr(arr(1),".")=0  and instr(arr(2),".")=0  then
  response.write "<font size=2>請先選擇你要上傳的圖片 [ <a href=# onclick=history.go(-1)>重新上傳</a> ]</font>"
response.end
end if
if instr(arr(0),".")<>0 then
response.write "<script>opener.document.forms[0].myface.value='" & arr(0) & "'</script>"
else
response.write "<script>opener.document.forms[0].myface.value=''</script>"
end if
if instr(arr(1),".")<>0 then
response.write "<script>opener.document.forms[0].myface1.value='" & arr(1) & "'</script>"
else
response.write "<script>opener.document.forms[0].myface1.value=''</script>"
end if
if instr(arr(2),".")<>0 then
response.write "<script>opener.document.forms[0].myface2.value='" & arr(2) & "'</script>"
else
response.write "<script>opener.document.forms[0].myface2.value='' </script>"
end if
set upload=nothing  ''刪除此對象

session("upface")="done"

Htmend iCount&" 個文件上傳結束!"

sub HtmEnd(Msg)
    set upload=nothing
response.write "<html><head><meta  http-equiv='Refresh' content='3 url=""Javascript:window.close();""'></head><body><center><br><br>文件上傳成功<br>謝謝你的支持!<br>本窗口三秒后自動關閉</center></body></html>"
   response.end
end sub
%>
</body>
</html>
upload.inc
<SCRIPT RUNAT=SERVER LANGUAGE=VBSCRIPT>

dim upfile_5xSoft_Stream

Class upload_5xSoft
  
dim Form,File,Version
  
PRivate Sub Class_Initialize
        dim iStart,iFileNameStart,iFileNameEnd,iEnd,vbEnter,iFormStart,iFormEnd,theFile
        dim strDiv,mFormName,mFormValue,mFileName,mFileSize,mFilePath,iDivLen,mStr
        Version=""
        if Request.TotalBytes<1 then Exit Sub
        set Form=CreateObject("Scripting.Dictionary")
        set File=CreateObject("Scripting.Dictionary")
        set upfile_5xSoft_Stream=CreateObject("Adodb.Stream")
        upfile_5xSoft_Stream.mode=3
        upfile_5xSoft_Stream.type=1
        upfile_5xSoft_Stream.open
        upfile_5xSoft_Stream.write Request.BinaryRead(Request.TotalBytes)
        
        vbEnter=Chr(13)&Chr(10)
        iDivLen=inString(1,vbEnter)+1
        strDiv=subString(1,iDivLen)
        iFormStart=iDivLen
        iFormEnd=inString(iformStart,strDiv)-1
        while iFormStart < iFormEnd
          iStart=inString(iFormStart,"name=""")
          iEnd=inString(iStart+6,"""")
          mFormName=subString(iStart+6,iEnd-iStart-6)
          iFileNameStart=inString(iEnd+1,"filename=""")
          if iFileNameStart>0 and iFileNameStart<iFormEnd then
           iFileNameEnd=inString(iFileNameStart+10,"""")
           mFileName=subString(iFileNameStart+10,iFileNameEnd-iFileNameStart-10)
           iStart=inString(iFileNameEnd+1,vbEnter&vbEnter)
           iEnd=inString(iStart+4,vbEnter&strDiv)
           if iEnd>iStart then
            mFileSize=iEnd-iStart-4
           else
            mFileSize=0
           end if
           set theFile=new FileInfo
           theFile.FileName=getFileName(mFileName)
           theFile.FilePath=getFilePath(mFileName)
           theFile.FileSize=mFileSize
           theFile.FileStart=iStart+4
           theFile.FormName=FormName
           file.add mFormName,theFile
          else
           iStart=inString(iEnd+1,vbEnter&vbEnter)
           iEnd=inString(iStart+4,vbEnter&strDiv)
        
           if iEnd>iStart then
            mFormValue=subString(iStart+4,iEnd-iStart-4)
           else
            mFormValue=""
           end if
           form.Add mFormName,mFormValue
          end if
        
          iFormStart=iformEnd+iDivLen
          iFormEnd=inString(iformStart,strDiv)-1
        wend
End Sub

Private Function subString(theStart,theLen)
dim i,c,stemp
upfile_5xSoft_Stream.Position=theStart-1
stemp=""
for i=1 to theLen
   if upfile_5xSoft_Stream.EOS then Exit for
   c=ascB(upfile_5xSoft_Stream.Read(1))
   If c > 127 Then
    if upfile_5xSoft_Stream.EOS then Exit for
    stemp=stemp&Chr(AscW(ChrB(AscB(upfile_5xSoft_Stream.Read(1)))&ChrB(c)))
    i=i+1
   else
    stemp=stemp&Chr(c)
   End If
Next
subString=stemp
End function

Private Function inString(theStart,varStr)
dim i,j,bt,theLen,str
InString=0
Str=toByte(varStr)
theLen=LenB(Str)
for i=theStart to upfile_5xSoft_Stream.Size-theLen
   if i>upfile_5xSoft_Stream.size then exit Function
   upfile_5xSoft_Stream.Position=i-1
   if AscB(upfile_5xSoft_Stream.Read(1))=AscB(midB(Str,1)) then
    InString=i
    for j=2 to theLen
      if upfile_5xSoft_Stream.EOS then
        inString=0
        Exit for
      end if
      if AscB(upfile_5xSoft_Stream.Read(1))<>AscB(MidB(Str,j,1)) then
        InString=0
        Exit For
      end if
    next
    if InString<>0 then Exit Function
   end if
next
End Function

Private Sub Class_Terminate  
  form.RemoveAll
  file.RemoveAll
  set form=nothing
  set file=nothing
  upfile_5xSoft_Stream.close
  set upfile_5xSoft_Stream=nothing
End Sub
   

Private function GetFilePath(FullPath)
  If FullPath <> "" Then
   GetFilePath = left(FullPath,InStrRev(FullPath, "/"))
  Else
   GetFilePath = ""
  End If
End  function

Private function GetFileName(FullPath)
  If FullPath <> "" Then
   GetFileName = mid(FullPath,InStrRev(FullPath, "/")+1)
  Else
   GetFileName = ""
  End If
End  function

Private function toByte(Str)
   dim i,iCode,c,iLow,iHigh
   toByte=""
   For i=1 To Len(Str)
   c=mid(Str,i,1)
   iCode =Asc(c)
   If iCode<0 Then iCode = iCode + 65535
   If iCode>255 Then
     iLow = Left(Hex(Asc(c)),2)
     iHigh =Right(Hex(Asc(c)),2)
     toByte = toByte & chrB("&H"&iLow) & chrB("&H"&iHigh)
   Else
     toByte = toByte & chrB(AscB(c))
   End If
   Next
End function
End Class


Class FileInfo
  dim FormName,FileName,FilePath,FileSize,FileStart
  Private Sub Class_Initialize
    FileName = ""
    FilePath = ""
    FileSize = 0
    FileStart= 0
    FormName = ""
  End Sub
  
Public function SaveAs(FullPath)
    dim dr,ErrorChar,i
    SaveAs=1
    if trim(fullpath)="" or FileSize=0 or FileStart=0 or FileName="" then exit function
    if FileStart=0 or right(fullpath,1)="/" then exit function
    set dr=CreateObject("Adodb.Stream")
    dr.Mode=3
    dr.Type=1
    dr.Open
    upfile_5xSoft_Stream.position=FileStart-1
    upfile_5xSoft_Stream.copyto dr,FileSize
    dr.SaveToFile FullPath,2
    dr.Close
    set dr=nothing
    SaveAs=0
  end function
End Class
</SCRIPT>
save.asp
<% dim dsn,conn
dsn="driver={sql server};server=127.0.0.1;uid=sa;pwd=;database=database"
set conn=server.createobject("adodb.connection")
conn.open dsn
%>
<% dim file,file1,file2
file=trim(request.form("myface"))
file1=trim(request.form("myface1"))
file2=trim(request.form("myface2"))
set rs=server.createobject("adodb.recordset")
sql="Insert Into sFile(image,image1,image2) Values('"& file &"','"& file1&"','"& file2&"')"
conn.execute(sql)
response.redirect "ok.asp"
%>
呵呵,代碼多了點。復制以上的代碼到你的機器上運行是不是你想要的結果!至于顯示圖片相信大家都明白了吧!我就不必多說了。值得一提的是此代碼不僅可以用于圖片上傳而是任何格式的文件都可以哦,至于文件大小也可以由你自己來定義哦!還有的就是我只定義了上傳三個要是要上傳更多的話稍為改下代碼就可以了。仔細看代碼就知道了是不是覺得很方便和實用。這個只不過是在我解決這個問題的時候用的一種方法而已。你要是有更好的方法來實現也可以來EMAIL告訴我!互相學習共同進步。第一次寫文章可能表達方面有語法問題。要是有什么問題也可以來EMAIL告訴我!我的郵箱:hushuowang@163.net,QQ:11313112。時間不早了,我要睡覺了!呼嚕呼嚕zzzZZZ....
(特別感謝hooke等高手一直以來的技術支持)小汪仔于2002/5/26晚

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一天堂无码专区| 亚洲tv在线观看| 日韩欧美国产成人| 国产精品亚洲аv天堂网| 国产成人在线播放| 精品在线欧美视频| 国产成人福利视频| 91精品久久久久久久久久久久久久| 国产精品69精品一区二区三区| 91黑丝高跟在线| 日韩精品在线私人| 亚洲乱码一区av黑人高潮| 日韩欧美国产高清91| 日韩在线免费视频观看| 色婷婷综合久久久久| 91黄色8090| 中文字幕精品在线| 亚洲精品国产精品国产自| 久久国产精品久久久久久久久久| 久久99精品久久久久久噜噜| 久久影视电视剧免费网站| 免费成人高清视频| 国产精品高清在线观看| 亚洲国产日韩欧美在线99| 国产欧美日韩丝袜精品一区| 亚洲精品国产综合区久久久久久久| 国产精品v日韩精品| 欧美专区国产专区| 色系列之999| 国产精品视频在线观看| 日韩在线观看精品| 久久全球大尺度高清视频| 国产精品偷伦免费视频观看的| 国模精品视频一区二区三区| 欧美国产中文字幕| 日韩精品高清在线观看| 最好看的2019年中文视频| 国产精品成人免费视频| 亚洲欧美中文字幕| 欧美日韩国产精品专区| 国产精品久久久久久av| 国产欧美日韩精品在线观看| 91精品视频一区| 色狠狠av一区二区三区香蕉蜜桃| 欧美丰满少妇xxxx| 日韩中文字幕网址| 国产精品国内视频| 国产亚洲精品美女| 亚洲一区www| 亚洲人在线观看| 夜夜狂射影院欧美极品| 日韩精品免费在线播放| 性视频1819p久久| 亚洲自拍偷拍色图| 国内精品国产三级国产在线专| 欧美日韩在线观看视频小说| 日韩视频免费看| 色综合伊人色综合网| 亚洲精品成a人在线观看| 亚洲人成电影网站色…| 色妞色视频一区二区三区四区| 亚洲欧美日本伦理| 亚洲成人av片在线观看| 91免费精品视频| 亚洲欧美日本另类| 国产精品成久久久久三级| 91在线观看免费观看| 国产美女主播一区| 久久久久久久久久婷婷| 亚洲va男人天堂| 中文字幕日本精品| 欧美大尺度激情区在线播放| 亚洲毛片在线观看| 国产精品国模在线| 日韩精品中文字幕久久臀| 中文日韩在线观看| 久久精品视频99| 亚洲黄色在线看| 久久亚洲精品网站| 日韩免费观看av| 久久激情视频免费观看| 亚洲aⅴ日韩av电影在线观看| 亚洲第一页中文字幕| 国产精品黄视频| 91chinesevideo永久地址| 久久久久久久久中文字幕| 欧美电影免费观看电视剧大全| 亚洲欧美一区二区精品久久久| 欧美猛少妇色xxxxx| 亚洲国产精品成人va在线观看| 成人国产在线激情| 不卡av在线播放| 欧美精品videos| 亚洲第一区中文字幕| 91在线免费网站| 国产精品视频一区国模私拍| 日韩欧美成人网| 亚洲天堂精品在线| 欧美一级大胆视频| 精品福利樱桃av导航| 海角国产乱辈乱精品视频| 国产精品视频资源| 在线亚洲欧美视频| 日本精品视频网站| 欧美丰满少妇xxxx| 中文字幕亚洲无线码a| 国产91成人在在线播放| 欧美成人免费一级人片100| 7777kkkk成人观看| 日韩一区二区av| 国产精自产拍久久久久久蜜| 中文字幕亚洲综合久久| 欧洲中文字幕国产精品| 中文字幕精品一区二区精品| 欧美日韩免费区域视频在线观看| 亚洲毛片在线看| 亚洲成人久久久| 国产深夜精品福利| 欧美性生交xxxxx久久久| 亚洲偷熟乱区亚洲香蕉av| 亚洲白虎美女被爆操| 国产在线拍偷自揄拍精品| 欧美做受高潮电影o| 亚洲国产精品久久久久秋霞不卡| 久久精品99国产精品酒店日本| 欧美中文字幕在线观看| 久久精品国产一区二区电影| 欧美日韩激情美女| 亚洲欧美综合图区| 91中文在线观看| 欧美日韩一区二区三区| 久久精品国产成人| 欧美富婆性猛交| 国产亚洲精品成人av久久ww| 久久视频中文字幕| 亚洲黄一区二区| 国产精品一二三在线| 日韩精品极品在线观看| 成人情趣片在线观看免费| 九九精品在线视频| 亚洲欧美国产一区二区三区| 黑人巨大精品欧美一区二区三区| 黑人极品videos精品欧美裸| 在线观看欧美日韩| 精品亚洲国产视频| 亚洲aa中文字幕| 亚洲第一页在线| 色婷婷综合成人| 成人xxxxx| 91九色国产视频| 国产91色在线播放| 国产免费成人av| 正在播放欧美视频| 欧美野外猛男的大粗鳮| 成人激情视频免费在线| 亚洲国产精品视频在线观看| 日韩免费在线观看视频| 国产99久久精品一区二区| 成人a视频在线观看| 91久久久久久久久久久久久| 国产欧美一区二区三区四区| 日韩黄色av网站| 久久91亚洲人成电影网站| 欧美亚洲视频在线看网址|