首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
Web开发
> 详细
关于在网站中图片入库和管理
时间:
2016-04-14 15:41:46
阅读:
154
评论:
0
收藏:
0
[点我收藏+]
标签:
本人有多年开发网站的经验,对图片的上传及管理一直感到十分头痛。最早以前是用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的图片时可能速度会受影响,当然系统性能好的话,强烈推荐使用这种方案。
代码比以前直接把图片放在目录下,复杂了!所以如果网站内图片用的地方不是很多的话,还是不要用这个方案!
关于在网站中图片入库和管理
标签:
原文地址:http://www.cnblogs.com/yanyao/p/5391150.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
36.VUE — 认识 Webpack 和 安装
2021-07-28
【PHP】上传图片翻转问题
2021-07-28
php对数字进行万。亿的转化
2021-07-28
五个 .NET 性能小贴士
2021-07-28
Three.js中显示坐标轴、平面、球体、四方体
2021-07-28
.net 5+ 知新:【1】 .Net 5 基本概念和开发环境搭建
2021-07-27
1.html,css
2021-07-27
基于Docker搭建 Php-fpm + Nginx 环境
2021-07-27
nginx + http + svn
2021-07-27
kubernets kube-proxy的代理 iptables和ipvs
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!