更改已有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参数的值,并且更新数据库中的链接即可,不需要再改动代码了。硬编码真是有些伤不起。不知道数据库中是不是也可以预先定义一个变量什么的,然后也直接绑定到配置文件中,这样以后也不需要手工更新数据库了。

 

 

 

posted @ 2013-02-26 16:55  elar  阅读(5819)  评论(3编辑  收藏  举报