`

commons-fileupload实现文件上传功能实例

    博客分类:
  • Java
 
阅读更多

Apache提供的commons-fileupload jar包实现文件上传确实很简单,最近要用Servlet/JSP做一个图片上传功能,在网上找了很多资料,大多是基于struts框架介绍的,还有些虽然也介绍common-fileupload的上传,但是那些例子比较老,有些类现在都废弃了。通过研究学习总结,终于完成了这个上传功能,下面与大家分享一下。

 

 

  • 案例场景
一个图书馆后台管理界面,需要提供上传图书图片的功能并且最终显示在页面中。
  • 实现效果
进入添加书籍页面,默认显示一个图片“暂无突破”(长宽均为200px),提供一个按钮“上传图片”,如下图效果。



  点击“上传图片”按钮,通过模式窗口弹出上传界面,如下图所示。


  通过“浏览”按钮选择指定图片,点击“上传”按钮进行上传,如果上传成功则弹出成功提示,用户点击“确定”后关闭弹出窗并自动将新图片显示在页面上,如下图所示。



 

 

  • 代码实现
①首先创建一个添加书籍页面:bookAdd.jsp
页面id为photo_id的hidden标签用于存储图片路径,方便提交到后台存放到数据库,id为img_id的<img>标签用于显示图片,所有图片都存放在服务器下,方便读取。然后一个关键js,点击button通过模式窗口弹出上传页面,在弹出模式窗口时定义了一个变量win,该变量用于获取模式窗口传回的图片路径值。
(注意:因为安全性问题图片不能图片不能随意存放,项目部署在服务器中,图片就只能放在该服务器下才能查看得到,如果一定要读取非当前服务器下的图片需要配置服务器的虚拟目录)
<html>
	<head>
		<title>添加书籍</title>
		<script type="text/javascript">
			//打开上传页面
			function openUpload(){
				var win = window.showModalDialog("<%=root%>/Admin/bookUpload.jsp","","dialogWidth:300px;dialogHeight:300px;scroll:no;status:no");
				if(win != null){
					document.getElementById("photo_id").value = win;
					document.getElementById("img_id").src = "<%=root%>/"+win;
				}
			}
		</script>
	</head>
	<body>
		<h5>添加书籍</h5><hr/>
			<p>
				书的封面:
				<label>
					<input type="hidden" id="photo_id" name="photo" value="images/noimg.png"><input type="button" onclick="openUpload()" value="上传图片"/><br/>
					<img id="img_id" alt="" src="<%=root%>/images/noimg.png" width="200px" height="200px">
				</label>
			</p>
      </body>
</html>
  ②创建上传图片页面,bookUpload.jsp
注意一定要定义<base>标签,当前模式窗口关闭时才能将数据返回到父窗体,<form>标签还要设置一个属性enctype="multipart/form-data"这样提交的文件才能被后台获取,点击“上传”button即可将文件向后台传送,剩下的重头戏就是后台上传处理了。
<html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=GBK">
		<meta http-equiv="pragma" content="no-cache" />
		<base target="_self">
		<title>书籍图片上传</title>
	</head>
	<body>
		<h5>图片上传</h5><hr/>
		<p style="color: red">${requestScope.errorMsg}</p>
		<form id="form1" name="form1" action="<%=root%>/BookServlet?type=bookUpload" method="post" enctype="multipart/form-data">
			<div>注:图片大小最大不能超过3M!</div>
			<div><input type="file" name="file_upload"/></div>
			<div><input type="submit" value="上传"/></div>
		</form>
	</body>
</html>
  ③创建一个普通的Servlet,下面只提供部分关键代码
红色代码部分是上传的关键代码,其它就是作为点缀了。完成这三步,一个简单的上传即实现了。
public class BookServlet extends HttpServlet {

	private String uploadPath = "eShop/upload/"; // 上传文件的目录
	private String tempPath = "eShop/uploadtmp/"; // 临时文件目录
	private String serverPath = null;
	
	private int sizeMax = 3;//图片最大上限
	private String[] fileType = new String[]{".jpg",".gif",".bmp",".png",".jpeg",".ico"};

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		serverPath = getServletContext().getRealPath("/").replace("\\", "/");
		//Servlet初始化时执行,如果上传文件目录不存在则自动创建
		if(!new File(serverPath+uploadPath).isDirectory()){
			new File(serverPath+uploadPath).mkdirs();
		}
		if(!new File(serverPath+tempPath).isDirectory()){
			new File(serverPath+tempPath).mkdirs();
		}

		DiskFileItemFactory factory = new DiskFileItemFactory();
		factory.setSizeThreshold(5*1024); //最大缓存
		factory.setRepository(new File(serverPath+tempPath));//临时文件目录
		
		ServletFileUpload upload = new ServletFileUpload(factory);
		upload.setSizeMax(sizeMax*1024*1024);//文件最大上限
		
		String filePath = null;
		try {
			List<FileItem> items = upload.parseRequest(request);//获取所有文件列表
			for (FileItem item : items) {
				//获得文件名,这个文件名包括路径
				if(!item.isFormField()){
					//文件名
					String fileName = item.getName().toLowerCase();
					
					if(fileName.endsWith(fileType[0])||fileName.endsWith(fileType[1])||fileName.endsWith(fileType[2])||fileName.endsWith(fileType[3])||fileName.endsWith(fileType[4])||fileName.endsWith(fileType[5])){
						String uuid = UUID.randomUUID().toString();
						filePath = serverPath+uploadPath+uuid+fileName.substring(fileName.lastIndexOf("."));
						item.write(new File(filePath));
						PrintWriter pw = response.getWriter();
						pw.write("<script>alert('上传成功');window.returnValue='"+uploadPath+uuid+fileName.substring(fileName.lastIndexOf("."))+"';window.close();</script>");
						pw.flush();
						pw.close();
					}else{
						request.setAttribute("errorMsg", "上传失败,请确认上传的文件存在并且类型是图片!");
						request.getRequestDispatcher("/Admin/bookUpload.jsp").forward(request,
								response);
					}
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
			request.setAttribute("errorMsg", "上传失败,请确认上传的文件大小不能超过"+sizeMax+"M");
			request.getRequestDispatcher("/Admin/bookUpload.jsp").forward(request,
					response);
		}
		
	}

  • 大小: 9.4 KB
  • 大小: 37 KB
  • 大小: 35.4 KB
  • 大小: 22.6 KB
4
1
分享到:
评论
5 楼 782763595 2016-04-23  
[flash=200,200][flash=200,200][flash=200,200][flash=200,200][flash=200,200][url][url][url][url][img][img][img][img][list]
[*][list]
[*][*][list]
[*][*][*][list]
[*][*][*][*]
引用
引用
引用
引用
引用
引用
[u][u][u][u][u][u][u][u][u][u][u][u][u][u][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/b][/u][/u][/u][/u][/u][/u][/u][/u][/u][u][u][u][u][u][u][u][u][u][u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u][/u]
  • [*][*][/list]
  • [*][*][/list]
    [*][/list]
    [/list][/img][/img][/img][/img][/url][/url][/url][/url][/flash][/flash][/flash][/flash][/flash]
    |||||||||||||||||
    ||||||||
    |||||||
    |||||||
    ||||||
    ||||||
    |||||
    |||||
    ||||
    ||||
    |||
    |||
    ||
    ||
    |
    |
    4 楼 白糖_ 2015-09-22  
    根号九加一 写道
    root的值是什么,是什么路径,能提供一下吗?

    request.getContextPath
    3 楼 根号九加一 2015-09-22  
    root的值是什么,是什么路径,能提供一下吗?
    2 楼 博克尔 2014-06-25  
    march_on 写道
    bookUpload.jsp中form 的action中action="<%=root%>/BookServlet?type=bookUpload"的type=bookUpload是干什么用的啊
    还有java代码中的span标签是乱码吧

    -----------------
    <span style="color: rgb(255, 0, 0);">if(!item.isFormField()){</span>

    <span>应该是楼主强调的地方,使用时应该把<span style="color: rgb(255, 0, 0);"></span>去掉,只要中间的代码

    为了那个返回值路径,我找了好久啊。。。。多谢楼主!
    1 楼 march_on 2012-08-07  
    bookUpload.jsp中form 的action中action="<%=root%>/BookServlet?type=bookUpload"的type=bookUpload是干什么用的啊
    还有java代码中的span标签是乱码吧

    相关推荐

      commons-fileupload-1.3.jar和commons-io-1.2.jar.zip

      结合这两个库,开发者可以轻松实现文件上传功能,包括验证文件类型、大小,处理多个文件上传,以及将上传的文件安全地保存到服务器的指定位置。在实际应用中,为了保证安全性,还需要注意防止恶意文件上传和DDoS攻击...

      commons-fileupload-1.3.3.jar commons-io-2.5.jar

      使用这两个库来实现文件上传功能的基本步骤如下: 1. **配置Servlet容器**:首先,你需要确保你的Servlet容器(如Tomcat、Jetty)已经配置了对multipart/form-data请求的支持。这通常涉及到在web.xml文件中配置一个...

      commons-fileupload文件上传实例

      本教程将详细介绍如何利用commons-fileupload实现文件上传功能,并提供一个简单的实例。 **一、Apache Commons FileUpload简介** Apache Commons FileUpload是Apache软件基金会开发的一个开源组件,专门处理HTTP...

      commons-fileupload 文件上传 图片上传 demo

      在`描述`中提到的`commons-fileupload-1.2.2.jar`和`commons-io.jar`是实现文件上传功能所必需的依赖库。`commons-fileupload-1.2.2.jar`是核心库,包含了文件上传的处理逻辑;`commons-io.jar`则是Apache Commons ...

      使用commons-fileupload上传文件

      通过使用`commons-fileupload`,开发者可以方便地在Java Web应用中实现文件上传功能,而无需关注底层的HTTP协议细节。这个组件提供了丰富的API,支持各种自定义选项,例如内存阈值、临时文件存储位置等,使得文件...

      commons-fileupload-1.0上传组件使用实例.

      接下来我们将根据提供的代码示例来详细了解如何使用`commons-fileupload`实现文件上传功能。 1. **前端表单设计**: - 创建一个HTML表单,用于收集用户上传的文件。 - 表单的`method`属性设置为`POST`,`enctype`...

      maven实现的commons-fileupload的demo

      总的来说,通过Apache Commons FileUpload库和Maven的配合,我们可以轻松地在Java Web项目中实现文件上传功能。这个"maven实现的commons-fileupload的demo"就是一个很好的起点,它帮助开发者理解如何整合这些工具来...

      commons-fileupload.rar;包括commons-fileupload-1.3.1-bin和commons-io-2.4

      Commons FileUpload是Apache软件基金会的一...在实际开发中,结合`commons-fileupload`和`commons-io`这两个库,可以方便地实现在Java Web应用中的文件上传功能,并且可以自定义各种策略以满足特定的安全性和性能要求。

      commons-fileupload-1.3.3-bin

      总的来说,Apache Commons FileUpload 1.3.3是Java Web开发中处理文件上传不可或缺的工具,结合Apache Commons IO,可以构建出高效、安全的文件上传功能。这两个库都是Java生态系统的重要组成部分,大大提高了开发...

      commons-fileupload-1.3.1.jar

      "commons-fileupload-1.3.1.jar" 是Apache Commons FileUpload项目的版本1.3.1的Java档案文件,这个库专门设计用于处理HTTP协议中的文件上传功能。在Web开发中,尤其是基于Java的服务器端应用程序,文件上传是常见的...

      commons-fileupload-1.3.2.jar

      Apache Commons FileUpload是一个Java库,专门用于处理HTTP协议中的文件上传功能。这个"commons-fileupload-1.3.2.jar"是该库的1.3.2版本,它支持Java Development Kit (JDK) 1.5及以上版本。在本文中,我们将深入...

      commons-fileupload-1.3.3-bin.tar.gz

      Apache Commons FileUpload是一个Java库,专门用于处理HTTP协议中的文件上传功能。这个库使得开发者能够轻松地在Web应用中添加上传文件的功能。标题中的"commons-fileupload-1.3.3-bin.tar.gz"是一个压缩包文件,...

      commons-fileupload-1.2.2.jar和commons-io-2.4.jar包

      Apache Commons项目提供了两个非常重要的库,即`commons-fileupload-1.2.2.jar`和`commons-io-2.4.jar`,它们是实现这些功能的关键工具。 `commons-fileupload-1.2.2.jar`是Apache Commons FileUpload的实现,它是...

      commons-fileupload-1.2.1.jar和commons-io-1.3.2.jar

      总结来说,`commons-fileupload-1.2.1.jar`和`commons-io-1.3.2.jar`是Java Web应用中处理文件上传的必备工具,它们提供了丰富的功能和良好的性能,简化了开发流程,使开发者可以专注于业务逻辑而不是底层细节。

      commons-fileupload-1.4-bin.zip

      Apache Commons FileUpload的主要功能在于解析HTTP请求中的multipart/form-data,这是HTML表单上传文件时常用的数据格式。它能够将上传的文件以Stream的形式处理,避免一次性加载到内存中,从而有效地处理大文件上传...

      java文件上传jar(commons-fileupload-1.2.1.jar,commons-io-2.0.1.jar)

      使用这两个库实现文件上传的基本步骤如下: 1. **配置DiskFileItemFactory**:设置临时文件路径和大小限制。 2. **创建ServletFileUpload**:使用`DiskFileItemFactory`实例初始化`ServletFileUpload`对象。 3. **...

      commons-fileupload文件上传实例代码

      在Java Web开发中,文件上传是一项常见的功能,Apache Commons FileUpload库为开发者提供了方便、灵活的文件上传解决方案。本教程将深入讲解如何使用`commons-fileupload`库处理中文乱码问题以及实现多文件上传。 ...

      commons-fileupload-1.2.2-bin.zip

      7. **与Struts、Spring等框架的整合**:Commons FileUpload库可以轻松与主流的Java Web框架集成,如Struts、Spring MVC等,使得文件上传功能的实现更加便捷。 总的来说,Apache Commons FileUpload库是Java开发人员...

      使用commons-fileupload-1.2.1实现文件上传操作

      在标题和描述中提到的"commons-fileupload-1.2.1"是该库的一个特定版本,它允许开发者在Java应用程序中实现文件上传的功能。这个版本在发布时可能是最新的,但现在可能已经有一些更新。 使用Apache Commons ...

    Global site tag (gtag.js) - Google Analytics