本文转自:http://amcucn.iteye.com/blog/264457。感谢作者
近日在工作当中,需要用到上传图片的功能,然而自己平时学习的时候只会使用struts的上传功能,但因为项目并没有使用struts,而是spring mvc ,最后不得不另寻它路。通过google和百度,看到了一些相关的介绍。经过自己的偿试,最终搞定利用spring mvc 上传文件的功能,完成图片的上传。如果只是为了上传图片,可以通过限制扩展名的形式达到目的。下面给出关键的代码部分。
关于spring的配置等我不在此介绍,下面的方法是基于spring mvc模式下的。
前台部分:
其实前台部分很简单,就是普通的FORM表单文件上传形式就可以。如:
- <form action="comm_addProduct.do?method=saveProduct" method="post" enctype="multipart/form-data">
- <input name="imgFile" id="imgFile" type="file" />
- </form>
这里只需注意关键的地方,就是在FORM表单里必须有enctype="multipart/form-data"属性。关于为什么要这个属性,我想对于做过文件上传的人来说都明白。我就不多说了。不会的搜索一下吧!这里的前台非常简单,只做一个演示。
当前台的表单提交到后台后,我们重点来注意后台是如何处理上传过来的文件的。关键代码如下:
- public void addImage(HttpServletRequest request,String path1,String path2) {
-
- MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
-
- MultipartFile imgFile1 = multipartRequest.getFile("imgFile");
-
-
- List fileTypes = new ArrayList();
- fileTypes.add("jpg");
- fileTypes.add("jpeg");
- fileTypes.add("bmp");
- fileTypes.add("gif");
-
-
- if(!(imgFile1.getOriginalFilename() ==null || "".equals(imgFile1.getOriginalFilename()))) {
- File file1 = this.getFile(imgFile1, fileTypes,path1,path2);
-
- }
-
-
- }
- <p>
- </p><p>其实上面的代码还是比较简单的,重点再于将我们常见的request对象转换为<span style="white-space: pre;">MultipartHttpRequest对象,有了这个对象,我们就可以得到用户上传的文件了。得到用户上传的文件之后,</span></p>
- <p><span style="white-space: pre;">我们就可以做一些我们想做的事情了。在上面我们还做了一些事,那就是判断用户上传的文件类型是否属于我们所定义的那个</span></p>
- <p>数组内的类型,至于如何判断是否属于允许上传的类型,我会在下面的方法当中给出。其实也可以将下面的代码写在一个方法里,但是了为重用,我就分开写了。也许我的做法不是最好的。相当于给大家一个方向吧!</p>
- <p> </p>
- <p>我们来看下面的两个方法,这两个方法最主要做两件事。一、判断用户上传的文件是否属于我们定义的类型范围之内,第二、将文件保存到指定的路径,这个路径是我们自己创建的。</p>
- <p>
- </p><pre name="code" class="java">
- private File getFile(MultipartFile imgFile,String typeName,String brandName,List fileTypes) {
- String fileName = imgFile.getOriginalFilename();
-
- String ext = fileName.substring(fileName.lastIndexOf(".")+1,fileName.length());
-
- ext = ext.toLowerCase();
-
- File file = null;
- if(fileTypes.contains(ext)) {
- file = this.creatFolder(typeName, brandName, fileName);
- try {
- imgFile.transferTo(file);
- } catch (IllegalStateException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- return file;
- }
-
-
- private File creatFolder(String typeName,String brandName,String fileName) {
- File file = null;
- typeName = typeName.replaceAll("/", "");
- typeName = typeName.replaceAll(" ", "");
- typeName = typeName.replaceAll(" ", "");
-
- brandName = brandName.replaceAll("/", "");
- brandName = brandName.replaceAll(" ", "");
- brandName = brandName.replaceAll(" ", "");
-
- File firstFolder = new File("c:/" + typeName);
- if(firstFolder.exists()) {
- File secondFolder = new File(firstFolder,brandName);
- if(secondFolder.exists()) {
- file = new File(secondFolder,fileName);
- }else {
- secondFolder.mkdir();
- file = new File(secondFolder,fileName);
- }
- }else {
- firstFolder.mkdir();
- File secondFolder = new File(firstFolder,brandName);
- if(secondFolder.exists()) {
- file = new File(secondFolder,fileName);
- }else {
- secondFolder.mkdir();
- file = new File(secondFolder,fileName);
- }
- }
- return file;
- }</pre>
- <p>
- </p><p>以上代码基本上实现了我们想要的功能。当然其中还是存在许多的问题,目前还只是达到了初步的功能,并没有写得非常严谨。关于在前台上如何利用javascript实现缩略图的功能,我会在后续的文章当中介绍!</p>
- <p> </p>
- <p> </p>
- <p> </p>
- <p> </p>
利用Spring MVC 上传图片文件
原文:http://www.cnblogs.com/panxuejun/p/5859557.html