对于实现文件上传功能来说,Commons-fileupload组件是一个不错的选择,本文使用它实现了单个文件及多个文件上传,这里将实现过程写出来与大家共享。
1.单个文件上传。
页面代码:
<!-- <br />
<br />
Code highlighting produced by Actipro CodeHighlighter (freeware)<br />
http://www.CodeHighlighter.com/<br />
<br />
-->
....
<
div
id
="content"
>
<
fieldset
><
legend
>
下載列表
</
legend
>
<
ul
>
<%
List
<
String
>
downloadList
=
(List
<
String
>
)request.getAttribute(
"
downloadList
"
);
if
(downloadList!
=
null
){
for
(
String
str:downloadList){
out.print(
"
<li><a href='DownloadFile?file=
"
+
str
+
"
'>
"
+
str
+
"
</a></li>
"
);
}
}
%>
</
ul
>
</
fieldset
>
<!--
enctype属性为表单定义了MIME编码方式,上传文件的表单enctype属性必须如此设置
-->
<
form
method
="post"
action
="UploadFile"
enctype
="multipart/form-data"
>
<
p
><
input
type
="text"
name
="fileIntro"
value
=""
/>
文件介绍
</
p
>
<
p
><
input
type
="file"
name
="myfile1"
value
="浏览文件"
/></
p
>
<
p
><
input
type
="submit"
value
="上传"
/></
p
>
</
form
>
</
div
>....
在上传表单中,既有普通文本域也有文件上传域,注意在Servlet中取它们和平常的做法不同:
Servlet代码:
<!-- <br />
<br />
Code highlighting produced by Actipro CodeHighlighter (freeware)<br />
http://www.CodeHighlighter.com/<br />
<br />
-->package
com.sitinspring.action;
import
java.io.File;
import
java.util.ArrayList;
import
java.util.Iterator;
import
java.util.List;
import
javax.servlet.RequestDispatcher;
import
javax.servlet.ServletException;
import
javax.servlet.http.HttpServlet;
import
javax.servlet.http.HttpServletRequest;
import
javax.servlet.http.HttpServletResponse;
import
org.apache.commons.fileupload.FileItem;
import
org.apache.commons.fileupload.FileItemFactory;
import
org.apache.commons.fileupload.disk.DiskFileItemFactory;
import
org.apache.commons.fileupload.servlet.ServletFileUpload;
import
com.sitinspring.util.UploadUtil;
/**
* 用于文件上传处理的Servlet
*
@author
sitinspring
*
* @date 2008-2-12
*/
public
class
UploadFileServlet
extends
HttpServlet {
private
static
final
long
serialVersionUID
=
56890894234786L
;
@SuppressWarnings(
"
unchecked
"
)
public
void
doPost(HttpServletRequest request, HttpServletResponse response)
throws
ServletException, java.io.IOException {
request.setCharacterEncoding(
"
UTF-8
"
);
//
文件上傳部分
boolean
isMultipart
=
ServletFileUpload.isMultipartContent(request);
if
(isMultipart
==
true
) {
try
{
FileItemFactory factory
=
new
DiskFileItemFactory();
ServletFileUpload upload
=
new
ServletFileUpload(factory);
//
得到所有的表单域,它们目前都被当作FileItem
List
<
FileItem
>
fileItems
=
upload.parseRequest(request);
Iterator
<
FileItem
>
iter
=
fileItems.iterator();
//
依次处理每个表单域
while
(iter.hasNext()) {
FileItem item
=
(FileItem) iter.next();
if
(item.isFormField()){
//
如果item是正常的表单域
String name
=
item.getFieldName();
String value
=
item.getString();
System.out.print(
"
表单域名为:
"
+
name
+
"
表单域值为:
"
+
value);
}
else
{
//
如果item是文件上传表单域
//
获得文件名及路径
String fileName
=
item.getName();
if
(fileName
!=
null
) {
File fullFile
=
new
File(item.getName());
//
如果文件存在则上传
if
(fullFile.exists()){
File fileOnServer
=
new
File(UploadUtil.getUploadPath(),
fullFile.getName());
item.write(fileOnServer);
System.out.println(
"
文件
"
+
fileOnServer.getName()
+
"
上传成功
"
);
}
}
}
}
}
catch
(Exception e) {
e.printStackTrace();
}
}
else
{
System.out.println(
"
the enctype must be multipart/form-data
"
);
}
//
取得服务器中已有文件的下載列表
List
<
String
>
fileListInServer
=
new
ArrayList
<
String
>
();
File dir
=
new
File(UploadUtil.getUploadPath());
String[] children
=
dir.list();
if
(children
!=
null
) {
for
(
int
i
=
0
; i
<
children.length; i
++
) {
fileListInServer.add(children[i]);
}
}
request.setAttribute(
"
downloadList
"
, fileListInServer);
//
跳回原頁面
RequestDispatcher dispatcher
=
request
.getRequestDispatcher(
"
/web/page/uploadtoserver.jsp
"
);
dispatcher.forward(request, response);
return
;
}
public
void
doGet(HttpServletRequest request, HttpServletResponse response)
throws
ServletException, java.io.IOException {
doPost(request, response);
}
}
从上面的代码可以看出,无论是否文件上传表单域都被当成了FileItem来处理,要区别开来使用isFormField()方法即可,返回真是常规表单域,返回假则是文件上传表单域。
2.多个文件上传到服务器端。
这里采用JS动态生成几个文件上传表单域即可,Servlet无需改变。
多文件上传页面代码如下:
<!-- <br />
<br />
Code highlighting produced by Actipro CodeHighlighter (freeware)<br />
http://www.CodeHighlighter.com/<br />
<br />
--><%
@ page contentType
=
"
text/html; charset=UTF-8
"
%>
<%
@page language
=
"
java
"
import
=
"
java.util.List
"
%>
<!
DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"
>
<
html
>
<
head
>
<
title
>
上传多個文件到服务器
</
title
>
<
meta
http-equiv
="Content-Type"
content
="text/html; charset=UTF-8"
>
<
link
rel
="stylesheet"
rev
="stylesheet"
href
="web/css/style.css"
type
="text/css"
/>
</
head
>
<
body
>
<
div
id
="bodyDiv"
>
<
div
id
="header"
>
<
jsp:include
page
="/web/page/branch/header.jsp"
/>
</
div
>
<
div
id
="sidebar"
>
<
jsp:include
page
="/web/page/branch/sidebar.jsp"
/>
</
div
>
<
div
id
="content"
>
<
fieldset
><
legend
>
下載列表
</
legend
>
<
ul
>
<%
List
<
String
>
downloadList
=
(List
<
String
>
)request.getAttribute(
"
downloadList
"
);
if
(downloadList!
=
null
){
for
(
String
str:downloadList){
out.print(
"
<li><a href='DownloadFile?file=
"
+
str
+
"
'>
"
+
str
+
"
</a></li>
"
);
}
}
%>
</
ul
>
</
fieldset
>
<!--
enctype属性为表单定义了MIME编码方式,上传文件的表单enctype属性必须如此设置
-->
<
form
name
="uploadForm"
method
="post"
action
="UploadFile"
enctype
="multipart/form-data"
>
<
p
><
input
type
="button"
value
="增加上传按钮"
onclick
="addUploadButton()"
/></
p
>
<
p
><
input
type
="file"
name
="myfile1"
value
="浏览文件"
/></
p
>
<
p
><
input
type
="submit"
value
="上传"
/></
p
>
</
form
>
</
div
>
<
div
id
="footer"
>
<
jsp:include
page
="/web/page/branch/footer.jsp"
/>
</
div
>
</
div
>
</
body
>
JS代码:
<!-- <br />
<br />
Code highlighting produced by Actipro CodeHighlighter (freeware)<br />
http://www.CodeHighlighter.com/<br />
<br />
--><
script LANGUAGE
=
"
JavaScript
"
>
<!--
var
count
=
1
;
function
addUploadButton(){
//
按ID找到FOrm
var
uploadForm
=
document.getElementById(
"
uploadForm
"
);
//
创建P元素
var
pNode
=
document.createElement(
"
p
"
);
//
累加Count以观察次数
count
=
count
+
1
;
pNode.innerHTML
=
"
<input type='file' name='myfile
"
+
count
+
"
' value='浏览文件'/>
"
;
//
将P元素添加到body中
uploadForm.appendChild(pNode);
}
//
-->
</
script
>
</
html
>
分享到:
相关推荐
基于SpringBoot的文件上传系统,前后端分离,单文件上传,多文件上传,大文件上传,断点续传,文件秒传,图片上传 项目经过严格测试,确保可以运行! 采用前后端分离的方式进行开发,实现了几种常用的文件上传功能...
之前发布一个大文件上传,但是问题太多,此版本相对上一个稳定得多 1,将压缩包里的 php_uploadprogress.dll 文件复制到你的PHP 安装目录里的扩展库文件夹 就是 ext文件夹下面 2,在你的服务器上随便一个地方(最好...
在Vue.js中,实现文件上传功能是常见的需求,尤其是在构建交互丰富的Web应用时。本篇将详细介绍Vue.js中实现多文件上传的相关知识点,以及如何使用`vue-upload-component`这个开源组件来帮助我们实现这一功能。 ...
为了简化这个过程,开发者通常会编写一个专门的文件上传类,以实现对上传过程的全面控制和错误处理。以下是对"PHP文件上传类"的详细解析: 1. **类的结构**: - 一个PHP文件上传类通常包含一系列的方法,如`upload...
在Java开发中,文件上传和下载是常见的功能需求,尤其在网络应用中,如网页、桌面应用或移动应用。为了实现这些功能,开发者通常需要引入特定的库或jar包。在这个场景下,"文件上传下载需要的jar包"指的是用于处理...
在Java开发中,多文件上传是一项常见的功能,尤其在Web应用中,用户可能需要一次性上传多个文件,如图片、文档等。本知识点将详细介绍如何在Java中实现这一功能,以及结合Flash实现上传界面并显示上传进度条。 1. *...
在这个“SpringMVC文件上传,多文件上传实例”中,我们将深入探讨如何在SpringMVC环境中实现文件上传功能,包括单个文件上传以及多个文件的批量上传。 1. **文件上传原理**: 文件上传是通过HTTP协议的POST请求来...
- **多文件上传**:支持单个文件和批量文件上传,提高用户操作效率。 2. **使用方法** 首先,你需要将压缩包中的PHP文件解压到你的项目目录中。然后,在需要实现文件上传功能的PHP脚本中引入该插件,通过调用其...
本想做个批量文件上传的功能(设想是客户选择一个目录后,程序能判断需要上传的文件上传到服务器指定目录下),结果没有做出来,在网上找了许多版本的批量上传程序,但实验效果不好,有的还需要下载分,上传文件也不能...
使用这个插件,开发者可以轻松集成到自己的项目中,实现高效、友好的文件上传功能。 HTML5文件上传的核心特性包括: 1. **多文件选择**:通过`<input type="file" multiple>`,用户可以在文件选择对话框中选取多个...
在.NET框架中,C#语言提供了丰富的功能来处理文件上传操作。对于初学者来说,理解并实现多文件上传是一项重要的技能,它可以帮助你构建交互性强、功能完善的Web应用程序。在这个"C# .NET FileUpload 多文件上传例子...
Bootstrap文件上传组件FileInput是一款强大的前端文件上传工具,尤其适合于需要实现文件批量上传的场景。这个组件基于Bootstrap框架,提供了美观的用户界面和丰富的功能,使得文件上传操作变得直观且易于实现。以下...
【标题】:多文件上传和展示 在网页开发中,多文件上传功能是常见的需求,尤其是在数据管理和资源共享的场景下。Bootstrap-fileinput 是一个流行的、功能丰富的jQuery插件,专门用于实现美观且实用的文件上传功能,...
在网络上找到的,纯JSP实现的文件上传程序,支持多文件的上传,例子是多文件的上传,稍微修改就可以变成单文件的上传或者更多文件的上传,控制成需要扩展名的文件上传,指定大小的文件上传等。程序目前上传文件存储...
"JSP多文件上传"是一个常见的需求,特别是在文件分享、在线教育或文档管理等场景。这个功能允许用户一次性选择并上传多个文件,提高了用户体验,减少了多次点击和等待时间。 实现JSP多文件上传,我们需要了解以下几...
这个功能对于处理大量文件上传的场景非常有用,比如在内容管理系统、图像库或者文件分享平台等应用中。 `MultiFileUploadField` 的核心特点包括: 1. **多选支持**:用户可以通过浏览器的文件选择对话框一次选择多...
在IT领域,尤其是在Web开发中,文件上传是一个常见的需求,特别是在处理大文件如高清图片、视频或大型文档时。jQuery,作为一个广泛使用的JavaScript库,提供了一系列的插件来解决这个问题。"jquery-大文件上传插件...
在Android开发中,文件上传,特别是图片上传,是常见的需求之一。这涉及到用户选择本地文件,通常是图片,然后通过网络接口将这些文件发送到服务器。本文将深入探讨如何实现Android平台上的多文件和单文件上传,以及...
总之,"通用 万能 HttpHandler webRequest 文件上传"是一个关于使用自定义HttpHandler和HttpWebRequest进行文件上传的技术主题。这个解决方案旨在提供一个高度可定制和可扩展的文件上传服务,以满足各种Web应用的...
接着,实现大文件上传的关键在于分块处理。我们可以将大文件分割成多个小块,然后逐个上传。这种方式降低了单次请求的压力,有利于网络不稳定时的恢复。PHP中,可以通过`fread()`函数读取文件的特定部分,`cURL`库则...