关于在网站中图片入库和管理!

王朝c#·作者佚名  2006-12-17
窄屏简体版  字體: |||超大  

本人有多年开发网站的经验,对图片的上传及管理一直感到十分头痛。最早以前是用FTP上传图片,但每次上传时,客户端都要下载插件。到后来的无组件上传,虽然解决了无客户端,但图片在网站上的管理显得有点零乱:

1、放图片目录要有可写,可删除的权限。

2、不能重名,所以要解决图片命名的方法。

3、比如图片是为发部新闻时上传的,当要删除该条新闻时,要另写代码对图片进行删除。因为权限的关系有可能,删除不了或者删除时页面运行的速度受影响。

4、还会图片很容易被别的网站,盗链。

所以,我认为将各模块中所上传的图片入库,集中管理是有好处的!

具体操作:新建一张表,用于专门存放图片的二进数据,一个自动加一的ID号。上传图片时,将图片的二进制数据入库后,然后得到该图片的ID号,在引用图片的记录只要记录下该ID号即可!

入库程序(以ASP为例):

demo1.asp

<%

'picBriny 为图片二进制数据。至于如何从表单中得到图片二进制数据,可以到网上查找无组件上传原理

'表名pic

'列名image 用于存放图片的二进制数据

'列名ID 自动加一

rs.Open "pic",conn,1,3

rs.AddNew()

rs.Fields("image").AppendChunk picBriny

rs.Update

'在这里就可以得到图片的ID号:rs.Fields("ID")

rs.Close

%>

图片显示的页面:

demo2.html

<html>

<head></head>

<body>

显示库中ID为1的图片

<img src='demo3.asp?id=1'>

</body>

</html>

图片出库程序(以ASP为例):

demo3.asp

<%

id=Request("id")

rs.Open "select image from pic where id="&id,conn,1,1

Response.BinaryWrite rs("image").getChunk(7500000)

rec.close

%>

综上所述可以解决上面的问题!

1、图片放库后就脱离了目录,就不用理会权限问题!

2、图片在表中都有自己的ID号,不会有重名问题!

3、当引用图片的记录要被删除时,只需在库中多删除一条记录!

4、如要防止盗链只需在出库程序:demo3.asp 里加上验证即可!

5、方便了其它各种对图片的管理!

目前想到这么多,当然也带来一些问题:

对系统数据库的要求提高了,上传几M的图片时可能速度会受影响,当然系统性能好的话,强烈推荐使用这种方案。

代码比以前直接把图片放在目录下,复杂了!所以如果网站内图片用的地方不是很多的话,还是不要用这个方案!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航