临摹微笑
现在假设在数据库中保存的是你所想要的图形格式(GIF, JPEG, BMP, TIFF, 等)现在来看看要怎么把它们从数据库中读出来。在ACCESS中使用了两个关键的技术来保存图形1。使用了bmp格式2。78个字节的文件头<%response.Expires = 0response.Buffer = Trueresponse.Clearresponse.contentType = "image/bmp"%>接着你要干的就是去掉那78个字节的OLE对象的文件头。<%Const OLEHEADERSIZE = 78nFieldSize = rs("photo").ActualSizeoleHeader = rs("photo").GetChunk(OLEHEADERSIZE)imageBytes = rs("photo").GetChunk(nFieldSize - OLEHEADERSIZE)Response.BinaryWrite imageBytes%>现在举一个例子:如果你要得到一个职工的信息,这段信息包括一个介绍和他的图象。并且要同时显示文字和图形。代码如下:(其中的theImg是一个代理页面)theImg.asp<%response.Expires = 0response.Buffer = Trueresponse.Clearresponse.contentType = Session("ImageType")response.BinaryWrite Session("ImageBytes")Session("ImageType") = ""Session("ImageBytes") = ""response.End%>Function SetImageForDisplay(field, contentType)OLEHEADERSIZE = 78contentType = LCase(contentType)select case contentTypecase "gif", "jpeg", "bmp"contentType = "image/" & contentTypebytes = field.valuecase "ole"contentType = "image/bmp"nFieldSize = field.ActualSizeoleHeader = field.GetChunk(OLEHEADERSIZE)bytes = field.GetChunk(nFieldSize - OLEHEADERSIZE)end selectSession("imageBytes") = bytesSession("imageType") = contentTypeEnd Function'注意的是,程序中只使用了4中格式:gif, jpeg, bmp , ole .<%sql = "select * from Employees"Set oRS = Server.CreateObject("ADODB.Recordset")oRS.CursorLocation = 3oRS.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 typeasp需要这些信息来联结到<IMG>中的属性3。只要把theImg放到你想显示图形的地方,就能够显示图象了