`

文件上传

 
阅读更多

对于实现文件上传功能来说,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的文件上传系统,前后端分离,单文件上传,多文件上传,大文件上传,断点续传,文件秒传,图片上传

    基于SpringBoot的文件上传系统,前后端分离,单文件上传,多文件上传,大文件上传,断点续传,文件秒传,图片上传 项目经过严格测试,确保可以运行! 采用前后端分离的方式进行开发,实现了几种常用的文件上传功能...

    php大文件上传,百兆文件上传,有进度条,有上传速度

    之前发布一个大文件上传,但是问题太多,此版本相对上一个稳定得多 1,将压缩包里的 php_uploadprogress.dll 文件复制到你的PHP 安装目录里的扩展库文件夹 就是 ext文件夹下面 2,在你的服务器上随便一个地方(最好...

    Vuejs文件上传组件多文件上传

    在Vue.js中,实现文件上传功能是常见的需求,尤其是在构建交互丰富的Web应用时。本篇将详细介绍Vue.js中实现多文件上传的相关知识点,以及如何使用`vue-upload-component`这个开源组件来帮助我们实现这一功能。 ...

    PHP文件上传类

    为了简化这个过程,开发者通常会编写一个专门的文件上传类,以实现对上传过程的全面控制和错误处理。以下是对"PHP文件上传类"的详细解析: 1. **类的结构**: - 一个PHP文件上传类通常包含一系列的方法,如`upload...

    文件上传下载需要的jar包 java文件上传下载

    在Java开发中,文件上传和下载是常见的功能需求,尤其在网络应用中,如网页、桌面应用或移动应用。为了实现这些功能,开发者通常需要引入特定的库或jar包。在这个场景下,"文件上传下载需要的jar包"指的是用于处理...

    java多文件上传实现

    在Java开发中,多文件上传是一项常见的功能,尤其在Web应用中,用户可能需要一次性上传多个文件,如图片、文档等。本知识点将详细介绍如何在Java中实现这一功能,以及结合Flash实现上传界面并显示上传进度条。 1. *...

    jsp自行增加上传文件的批量文件上传

    本想做个批量文件上传的功能(设想是客户选择一个目录后,程序能判断需要上传的文件上传到服务器指定目录下),结果没有做出来,在网上找了许多版本的批量上传程序,但实验效果不好,有的还需要下载分,上传文件也不能...

    SpringMVC文件上传,多文件上传实例

    在这个“SpringMVC文件上传,多文件上传实例”中,我们将深入探讨如何在SpringMVC环境中实现文件上传功能,包括单个文件上传以及多个文件的批量上传。 1. **文件上传原理**: 文件上传是通过HTTP协议的POST请求来...

    php文件上传插件(简洁好用的上传插件)

    - **多文件上传**:支持单个文件和批量文件上传,提高用户操作效率。 2. **使用方法** 首先,你需要将压缩包中的PHP文件解压到你的项目目录中。然后,在需要实现文件上传功能的PHP脚本中引入该插件,通过调用其...

    bootstrap 文件上传组件 fileinput 实现文件批量上传

    Bootstrap文件上传组件FileInput是一款强大的前端文件上传工具,尤其适合于需要实现文件批量上传的场景。这个组件基于Bootstrap框架,提供了美观的用户界面和丰富的功能,使得文件上传操作变得直观且易于实现。以下...

    C# .NET FileUpload 多文件上传例子

    在.NET框架中,C#语言提供了丰富的功能来处理文件上传操作。对于初学者来说,理解并实现多文件上传是一项重要的技能,它可以帮助你构建交互性强、功能完善的Web应用程序。在这个"C# .NET FileUpload 多文件上传例子...

    html5文件上传插件

    使用这个插件,开发者可以轻松集成到自己的项目中,实现高效、友好的文件上传功能。 HTML5文件上传的核心特性包括: 1. **多文件选择**:通过`&lt;input type="file" multiple&gt;`,用户可以在文件选择对话框中选取多个...

    多文件上传和展示

    【标题】:多文件上传和展示 在网页开发中,多文件上传功能是常见的需求,尤其是在数据管理和资源共享的场景下。Bootstrap-fileinput 是一个流行的、功能丰富的jQuery插件,专门用于实现美观且实用的文件上传功能,...

    JSP无组件文件上传

    在网络上找到的,纯JSP实现的文件上传程序,支持多文件的上传,例子是多文件的上传,稍微修改就可以变成单文件的上传或者更多文件的上传,控制成需要扩展名的文件上传,指定大小的文件上传等。程序目前上传文件存储...

    JSP多文件上传(同时上传)

    "JSP多文件上传"是一个常见的需求,特别是在文件分享、在线教育或文档管理等场景。这个功能允许用户一次性选择并上传多个文件,提高了用户体验,减少了多次点击和等待时间。 实现JSP多文件上传,我们需要了解以下几...

    EXTJS 多文件上传

    这个功能对于处理大量文件上传的场景非常有用,比如在内容管理系统、图像库或者文件分享平台等应用中。 `MultiFileUploadField` 的核心特点包括: 1. **多选支持**:用户可以通过浏览器的文件选择对话框一次选择多...

    android 文件上传(多个或单个),图片上传

    在Android开发中,文件上传,特别是图片上传,是常见的需求之一。这涉及到用户选择本地文件,通常是图片,然后通过网络接口将这些文件发送到服务器。本文将深入探讨如何实现Android平台上的多文件和单文件上传,以及...

    通用 万能 HttpHandler webRequest 文件上传

    总之,"通用 万能 HttpHandler webRequest 文件上传"是一个关于使用自定义HttpHandler和HttpWebRequest进行文件上传的技术主题。这个解决方案旨在提供一个高度可定制和可扩展的文件上传服务,以满足各种Web应用的...

    jquery-大文件上传插件,支持分片上传,断点续传

    在IT领域,尤其是在Web开发中,文件上传是一个常见的需求,特别是在处理大文件如高清图片、视频或大型文档时。jQuery,作为一个广泛使用的JavaScript库,提供了一系列的插件来解决这个问题。"jquery-大文件上传插件...

    php大文件上传

    接着,实现大文件上传的关键在于分块处理。我们可以将大文件分割成多个小块,然后逐个上传。这种方式降低了单次请求的压力,有利于网络不稳定时的恢复。PHP中,可以通过`fread()`函数读取文件的特定部分,`cURL`库则...

Global site tag (gtag.js) - Google Analytics