zoukankan      html  css  js  c++  java
  • java web应用用户上传图片的存储地址

    原来工程的上传图片存储地址在web应用的目录下,并且是硬编码到其中的:

    每次使用maven tomcat:redeploy以后,这个目录就没有了。

    现在想要把上传图片的位置移动到tomcat的webapps目录中专门存放图片的一个目录下。

    即,新建的一个images目录用来存放web应用的图片们。

    这样就把工程和用户上传图片分离了,以后在redeploy时也不用预先备upload目录,然后再拷贝回去,因而在web应该更新时比较方便些。此外,还想改变文件路径被硬编码到java文件中的现状,所以将文件的存储位置预先定义在web.xml中,这样将来再改变位置的时候就不需要再回去改动代码了。

    要完成上述目的,需要更新的地方有三个:

    一、在web.xml中设置保存上传图片的路径

    二、更新与上传图片相关的java类,去掉硬编码的部分,将路径改为从servletContext读取,由web.xml统一配置。

    三、更新MySQL数据库中已经存在的数据中的链接路径

    下面记录更新的过程:

    一、在web.xml中设置保存上传图片的路径

     <context-param>
    <param-name>UPLOAD_IMAGE_PATH</param-name>
    <param-value>../images/wiqun/upload/</param-value>
    </context-param>

    二、更新与上传图片相关的java类

    上传图片使用的是smartUpload。先通过servletContext获得UPLOAD_IMAGE_PATH参数的地址,保存在image_path这个String变量中。

    2.1从servletContext中获得上传文件保存的地址

    String image_path = this.getServletContext().getInitParameter("UPLOAD_IMAGE_PATH");//从配置文件中读取要保存的位置

    这个地址在使用之前别忘了在代码中测试一下是否存在该目录,若不存在要创建,否则会抛出exception。

    2.2使用指定的路径保存上传的图片

    复制代码
     1 su.upload();
     2 
     3 for (int i = 0; i < su.getFiles().getCount(); i++) {
     4       com.wiqun.smartUpload.File myfile = su.getFiles().getFile(i);
     5     //直接提取或另外生成图片的文件名,保存在fileName变量中
     6      ........ 7     //将上传的图片以fileName为名,保存到image_path指定的目录下
     8       myfile.saveAs(image_path + fileName); 9      
    10 }       
    复制代码

    第8行中的image_path就是在web.xml文件中指定的UPLOAD_IMAGE_PATH参数的值。

    2.3测试

    UPLOAD_IMAGE_PATH参数指定的目录下:

    三、更新MySQL数据库中已经存在的测试数据中的链接路径

    数据库中存有曾经的测试数据,其中的图片路径还是"upload/xxxxxx.jpg"格式的。现在要把它们替换成我们在web.xml中定义的新路径"../images/wiqun/upload/xxxxx.jpg"格式。此过程可以使用MySQL的replace语句来完成。现在,我们要把sight表格中的introduction列中的“upload/”替换成“../images/wiqun/upload/”,语句为:

    update sight set introduction = replace(introduction,'upload/','../images/wiqun/upload/');

    格式为 update 表名 set 列名 = replace(列名,'被替换的字串','替换的字串')

    执行前,数据库introduction列部分截图如下:

    wiqun是web应用的名称。当前所有用户上传的图片都是存放在wiqun目录的upload目录下,就像文章一开始所显示的截图。

    在执行了上述replace语句后,MySQL提示如下:

    现在再看看数据库里的状态:

    可以看到路径名都已经完成替换了。
    在浏览器中测试图片是否可以浏览:

    至此,就完成了web应用中,上传文件的路径替换。

    以后如果还要更改路径,只需要更改web.xml中UPLOAD_IMAGE_PATH参数的值,并且更新数据库中的链接即可,不需要再改动代码了。硬编码真是有些伤不起。不知道数据库中是不是也可以预先定义一个变量什么的,然后也直接绑定到配置文件中,这样以后也不需要手工更新数据库了。

    至于别的大神说用云存储的方式进行存储,小编在此还不会,哪位大神要会的话进行个留言,万分感谢!

  • 相关阅读:
    Base64
    HBase搭建
    解决Zookeeper无法启动的问题
    docker基础知识之挂载本地目录
    VMware升级到15版本虚拟机黑屏的解决方法
    docker端口映射或启动容器时报错Error response from daemon: driver failed programming external connectivity on endpoint
    MQTT 入门介绍
    OpeTSDB的Configuration配置
    js中ES6的Set的基本用法
    Review-JVM
  • 原文地址:https://www.cnblogs.com/yangchengdebokeyuan/p/7560541.html
Copyright © 2011-2022 走看看