|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
ASP在国内异常流行,因为国内大多使用的是盗版的Windows和盗版的SQLServer,而ASP+COM+SQLServer实际上也是一种不错的搭配,其性能也不输于PHP+MYSQL,特别是Windows系统和SQLServer都有图形界面,比APACHE和MYSQL易于维护,因此对于不重视知识产权的国家来说也是一种不错的选择。工具|数据|数据库|显现在ASP中,我们常常必要在Web页面上显现以二进制体例保留在数据库中的图片。一样平常的图片显现没有甚么成绩,由于这方面的文章已良多了,我就不再论述。但偶然候数据库中的图片是经由过程其他办公软件输出的,大概经由过程其他体例,好比在Access中间接增加。这时候,图片以OLE工具的体例保留在数据库中,在图片实在内容的后面,还保留了一些其他的信息,好比图片的路径和文件名,等等。假如我们还用一样平常的输入体例的话,就会堕落,招致图片不克不及显现。
幸亏jpeg,bmp等图像格局中在图片内容的开首都有一个SOImarker,这个marker关于jpeg来讲是FFD8,而关于bmp是424D.如许一来,我们只需找到这个marker的地位,就能够疏忽后面的内容而间接从这里入手下手输入图片。以SQLserver为例,代码以下:
<%
-------------------------------------------------------------------------------------
函数:functionShowJpegField(field)
inelm(Archimond【阿克蒙德】)fromcsdn
Date:2003-12-6更新
功效:获得保留jpeg图片的字节数组中的SOImarker入手下手地位,并从该地位输入真实的图片信息
注:jpeg格局的SOImarker:FFD8
bmp格局:424D
参数:图片字段
前往值:无
挪用典范:ShowJpegField(rs("picture1"))
注重:挪用此函数之前,必要先声名response.write的MIME范例为"image/jpeg"
-------------------------------------------------------------------------------------
functionShowJpegField(field)
dimsize,i,j
要输入字段的总字节数
size=field.ActualSize
轮回找到SOImarker的地位
fori=1tosize
ifAscB(MidB(field,i,1))=&HFFandAscB(MidB(field,i+1,1))=&HD8then
exitfor
endif
next
疏忽后面的无用信息,从SOImarker入手下手输入真实的图片信息
forj=itosize
response.BinaryWriteMidB(field,j,1)
next
endfunction
%>
<%
--------主程序入手下手------------------------------
dimconn
setconn=Server.CreateObject("ADODB.Connection")
conn.open("Provider=SQLOLEDB.1;Password=sa;PersistSecurityInfo=True;UserID=sa;InitialCatalog=123;DataSource=MARK")
sql="select*fromxinxi_mishuchu"
setrs=conn.execute(sql)
声明输入范例,清空输入缓冲区
response.buffer=true
response.clear
response.ContentType="image/jpeg"
挪用函数输入图片
ShowJpegField(rs("picture1"))
打完收功!
rs.close:setrs=nothing
conn.close:setconn=nothing
%>
假如是其他格局的图片,如bmp,gif等,输入办法相似,只不外是SOImarker分歧罢了。
因为作者程度无限,毛病的地方在所不免,接待人人品评斧正。
</p>对用户来说可预见费用、节约费用,可以做到花少钱办大事。由于省去了购买软件和硬件等的前期费用,用户可以租用较高级的应用软件。ASP的收费是根据软件的类型、客制化程度、用户数量、服务期限来定的,对客户来说这笔费用是可以预见的。方便于客户应用软件的升级。 |
|