变态重口极致另类在线-波多久久夜色精品国产-波多野结衣在线观看一区-波多野结衣在线观看一区二区-污污的网站免费阅读-污污视频网址

當前位置: 首頁IT技術 → 關于ASP中從ACCESS數據庫中讀取images的方法分享

關于ASP中從ACCESS數據庫中讀取images的方法分享

更多

本文主要跟大家分享介紹的是ASP程序如何從access數據庫中讀取圖形,希望對大家有用。

如何從ACCESS數據庫中讀取images

  1。ACCESS和FoxPro數據庫中的圖形格式

  當瀏覽器遇到一個<IMG>標志時,它會根據你設定的src屬性來下載文件。這可能是一個圖形文件或則是一個ASP頁面。如果是一個返回gif二進制的ASP頁面,瀏覽器需要知道返回的是什么格式的圖形文件,因為這個原因,就需要指定content type,為image/gif,image/bmp,image/jpeg或則其他什么的。

   Response.contentType = "image/gif"

  但這會導致另外一個問題,那就是我們只能夠顯示gif格式的圖象,或則說保存在數據庫中的東西只能夠是gif格式的了。但是一些數據庫是使用gif格式保存的,但是另外一些則是使用jpeg格式保存的,甚至其他是采用OLE方式來保存圖形的。所以我們必須根據圖形的格式來設置response的content type.

  注意的是你也可以從一個文件中新建一個位圖對象,但使用這樣的方式保存在數據庫中的圖形格式是瀏覽器不能夠識別的。當你往數據庫中保存圖象時,你應該知道你需要使用什么格式來保存,你可以把文件中的每一個字節保存下來,或則通過ACCESS/Foxpro的把圖形保存為一個OLE格式。

  你使用什么格式保存圖象決定了你在ASP中用什么格式來讀出圖形來。具體來說,如果你在ACCESS/FoxPro中將圖形保存為bmp,gif,jpeg(這個必須要使用到ACCESS/FoxPro的OLE對象,即使用ACCESS的插入對象對話框來完成),這是當你使用image/bmp時瀏覽器是不能夠解釋的。

  現在假設在數據庫中保存的是你所想要的圖形格式(GIF, JPEG, BMP, TIFF, 等)現在來看看要怎么把它們從數據庫中讀出來。

  在ACCESS中使用了兩個關鍵的技術來保存圖形

  1。使用了bmp格式

  2。78個字節的文件頭

   <%
       response.Expires = 0
       response.Buffer  = True
       response.Clear
       response.contentType = "image/bmp"
   %>

  接著你要干的就是去掉那78個字節的OLE對象的文件頭。

   <%
       Const OLEHEADERSIZE = 78
       nFieldSize = rs("photo").ActualSize
       oleHeader = rs("photo").GetChunk(OLEHEADERSIZE)
       imageBytes = rs("photo").GetChunk(nFieldSize - OLEHEADERSIZE)
       Response.BinaryWrite imageBytes
   %>

  現在舉一個例子:

  如果你要得到一個職工的信息,這段信息包括一個介紹和他的圖象。并且要同時顯示文字和圖形。代碼如下:(其中的theImg是一個代理頁面)

  theImg.asp

   <%
       response.Expires = 0
       response.Buffer  = True
       response.Clear
       response.contentType = Session("ImageType")
       response.BinaryWrite Session("ImageBytes")
       Session("ImageType") = ""
       Session("ImageBytes") = ""
       response.End
   %>
   Function SetImageForDisplay(field, contentType)
       OLEHEADERSIZE = 78   
       contentType = LCase(contentType)
       select case contentType
           case "gif", "jpeg", "bmp"
              contentType = "image/" & contentType
              bytes = field.value
           case "ole"
              contentType = "image/bmp" 
              nFieldSize = field.ActualSize
              oleHeader = field.GetChunk(OLEHEADERSIZE)
              bytes = field.GetChunk(nFieldSize - OLEHEADERSIZE)
       end select
       Session("imageBytes") = bytes
       Session("imageType") = contentType
   End Function
'注意的是,程序中只使用了4中格式:gif, jpeg, bmp , ole . 

   <%
      sql = "select * from Employees"
      Set oRS = Server.CreateObject("ADODB.Recordset")
      oRS.CursorLocation = 3
      oRS.Open sql, "DSN=NW"
      SetImageForDisplay oRS("photo"), "ole"
      Set oRS.ActiveConnection = Nothing
   %>

  要顯示圖象的話,只需要在另外一個asp中,假設為getEmpInfo.asp中

   <img src="theImg.asp"</img>

  但這還有一個問題,因為對每個職工的圖形都使用了同一個"theImg.asp"文件,應該再小小修改一下:

   <img src="theImg.asp?temp=<%= Request.Form("empLastName")%>"</img>

  最后再說一點,如何顯示多幅圖象呢?也就是說如果數據庫中有多個字段都保存了圖形,怎么辦?其實解決辦法很簡單,只要給SetImageForDisplay多加一個參數就是用來保存圖形的一個session變量。

  例如:

   SetImageForDisplay oRS1("photo"), "ole", "empPhoto"
   SetImageForDisplay oRS2("logo"), "gif", "compLogo"

   <img src="theImg2.asp?varName=empPhoto&temp=<%= Request.Form("empLastName")%>">
   <img src="theImg2.asp?varName=compLogo&temp=<%= Request.Form("imgCode")%>">

  使用這個方法能夠完成下面的功能:

  1。能夠從數據庫中取出圖形字段。(你唯一需要知道的是數據庫中的圖形是什么格式bmp?gif?jpeg?ole?)

  2.采用session變量 來保存圖形的字節數和content type,asp需要這些信息來聯結到<IMG>中的屬性

  3。只要把theImg放到你想顯示圖形的地方,就能夠顯示圖象了。

熱門評論
最新評論
昵稱:
表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
字數: 0/500 (您的評論需要經過審核才能顯示)
主站蜘蛛池模板: 国产午夜在线观看视频播放 | 欧美人与性禽xxxx | 国产91在线chines看 | 综合558欧美成人永久网站 | 亚洲欧美日韩v中文在线 | 欧美日韩亚洲色图 | 老司机av| 久久精品国产亚洲精品2020 | 欧美中文字幕在线视频 | 日本一道本在线视频 | 亚洲高清在线看 | freexxx日本| 欧美日韩黄色大片 | 久久成人亚洲香蕉草草 | 另类视频在线 | aaa一级特黄 | 成年美女黄网色大观看全 | 日本夜夜 | 欧美成人手机在线视频 | 日日噜噜噜夜夜爽爽狠狠 | 狠狠干夜夜爱 | 成人黄色免费在线观看 | 六月丁香在线观看 | 欧美性一级交视频 | 免费在线观看的毛片 | 国产午夜精品片一区二区三区 | 一区二区精品久久 | 播9公社在线精品中文字幕 波少野结衣色在线 | 亚洲精品动漫在线 | 日韩欧美亚洲一区二区综合 | 国产无套在线观看视频 | 在线视频一区二区三区在线播放 | 特级黄色网 | 欧美国产91 | 午夜视频在线观看免费视频 | 亚洲欧美国产另类 | 黄色一级录像片 | 男女日批视频在线永久观看 | 国产视频你懂的 | 欧美日本一区 | 香焦视频在线观看黄 |