zoukankan      html  css  js  c++  java
  • 关于在网站中图片入库和管理

      • 本人有多年开发网站的经验,对图片的上传及管理一直感到十分头痛。最早以前是用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的图片时可能速度会受影响,当然系统性能好的话,强烈推荐使用这种方案。 
        代码比以前直接把图片放在目录下,复杂了!所以如果网站内图片用的地方不是很多的话,还是不要用这个方案! 

  • 相关阅读:
    asp.net tutorial(http://www.cnblogs.com/mqingqing123/archive/2006/04/16/376358.html)
    CSS五日教程 (reference to http://www.tuqiu.com/study/css/day1_1.php)
    CSS教程 http://www.lnnu.edu.cn/dandu/hqcy/internet/jiaocheng/css/css.htm
    关于Spoolsv.exe
    理解MVC
    Design Patterns(十五):Command PatternVB代码
    Design Patterns(十六):Interpreter PatternVB代码
    Design Patterns(十三):Proxy PatternVB代码
    Design Patterns(二十):Observer PatternVB代码
    【转】VB中动态编程的技巧和挑战:多重分派
  • 原文地址:https://www.cnblogs.com/yanyao/p/5391150.html
Copyright © 2011-2022 走看看