`
小妞咕嘟
  • 浏览: 9787 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

使用用uploadFile组件实现简单上传的demo

阅读更多
最近公司做个ftp下载服务器,当然要做后台管理,所以其中也要上传,哎,项目现在需求还是不稳定,天天改啊改,把这个上传的部分跟大家分享下吧,希望大家可以给点意见,我做的支持多文件上传,当然其中我也参考了一些网络资料,起初本来想用swf组件也用上的,但是中间遇到了样式调整问题,而且不好调,就干脆没用啦,
1.jsp 主要代码:
  <script language="javascript">
     var num = 0;
     
     function upload(){
        
        
         document.getElementById("status").innerHTML = "文件上传中...";
         document.getElementById("form").action = "AddFileTest" ;
         document.getElementById("form").submit();
     
}
    function additem(id)
    {
     var row,cell,str;

     row = eval("document.all["+'"'+id+'"'+"]").insertRow();
     if(row != null )
        {
           cell = row.insertCell();
           str="<input type="+'"'+"file"+'"'+"id=uploadFile["+ num +"].file"+  " name=uploadFile["+ num +"].file><input type="+'"'+"button"+'"'+" value="+'"'+"删除"+'"'+" onclick='deleteitem(this,"+'"'+"tb"+'"'+");'>"
          cell.innerHTML=str;
        }
     num++;
    }
    function deleteitem(obj,id)
    {
     var rowNum,curRow;
     curRow = obj.parentNode.parentNode;
     rowNum = eval("document.all."+id).rows.length - 1;
     eval("document.all["+'"'+id+'"'+"]").deleteRow(curRow.rowIndex);
    }
    function callback(msg)
    {
     document.getElementById("status").innerHTML = "文件上传完成...<br>" + msg;
    }
    </script>

</head>
    <body bgcolor="#ffffff">
    <fieldset>
    <div id="status"></div>
  
<form id="form"  name="form"  method="post"  enctype="multipart/form-data">
<table id="tb">
     </table>

<iframe name='hidden_frame' id="hidden_frame" style="display:none"></iframe>
    <input type="button" name="btnAddFile" value="增加文件" onclick="additem('tb')"/>
    <input type="button" name="btnUpload" value="上传" onclick="upload()"/>

</form>
</fieldset>






2.servlet代码:


package download.control;

import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;

import javax.servlet.ServletConfig;
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.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

public class AddFileServlet   extends  HttpServlet  {


public  AddFileServlet(){

super();
}


public void init() throws ServletException {

System.out.println("+++++++++++AddFileServlet++++++++++");
}

public  void  init(ServletConfig  config)  throws  ServletException{

super.init(config);

System.out.println("++++++++ AddFileServlet init(config)  ++++++++") ;

}

   public void destroy() {
super.destroy();

     }

   public void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {

        this.doPost(request, response);
     }


   public void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
   System.out.println("++++++++ AddFileServlet doPost  ++++++++") ;
   response.setContentType("text/html; charset=UTF-8");
   try {
   request.setCharacterEncoding("UTF-8");
   } catch (UnsupportedEncodingException e) {

   e.printStackTrace();
   }
   PrintWriter out = response.getWriter();
  
   /*  定义上传文件的存放路劲*/
      
      String   base   =  request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
     
      /*定义上传文件的缓存位置*/
     
      String  temPath     =  request.getSession().getServletContext().getRealPath("")+"\\admin\\upload\\temp";
     
     
     /* 当缓存或存储路劲不存在时将自动创建文件*/
      if (!new File(base).isDirectory()){
new File(base).mkdirs();
     
      }
      if(!new File(temPath).isDirectory()){
      new File(temPath).mkdirs();
     
      }
     
      try{
      FileItemFactory factory = new DiskFileItemFactory();
    
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setHeaderEncoding("UTF-8");
upload.setSizeMax(10002400000l);
List<FileItem> items=null;

try{
  items = upload.parseRequest(request);
}catch (FileUploadException e) {
// TODO: handle exception
   e.printStackTrace();
   }
 
Iterator i = items.iterator();
FileItem file = null;
         while (i.hasNext()) {
       FileItem  item = (FileItem) i.next();
        System.out.println(item);
       System.out.println(item.getFieldName());
       System.out.println(item.getName());
       System.out.println(i.hasNext());
      
         
         if(item.isFormField()){
        System.out.println(item.getName());
         }else{
       file =item;
       String fileName =  file.getName();
       System.out.println(fileName);
           if(fileName!=null&&fileName!=""){
          
          /* 得到文件类型 */
              String  fileType = file.getName().substring(file.getName().lastIndexOf("."), file.getName().length());
          
             /* 判断文件类型*/
         
              System.out.println(fileType);
          /*  在本需求中管理员上传文件类型为压缩文件.war/.rar/.giz/.apk*/
             if(fileType.toLowerCase().equals(".rar")||fileType.toLowerCase().equals(".giz")||fileType.toLowerCase().equals(".apk")){
           
               base+="\\RarVsGiz\\" ;
         
                 }else if(fileType.toLowerCase().equals(".txt")||fileType.toLowerCase().equals(".doc")||fileType.toLowerCase().equals(".xls")||fileType.toLowerCase().equals(".pdf")
                
                
                 ||fileType.toLowerCase().equals(".ppt")){
            
                     base+="\\Text\\";
                 
                 }else if(fileType.toLowerCase().equals(".wmv") || fileType.toLowerCase().equals(".rm") || fileType.toLowerCase().equals(".rmvb") || fileType.toLowerCase().equals(".avi")
                  || fileType.toLowerCase().equals(".flv")|| fileType.toLowerCase().equals(".f4v")||fileType.toLowerCase().equals(".mp4")){
                
                     base+="\\Video\\";
                
                 }else if(fileType.toLowerCase().equals(".jpg") || fileType.toLowerCase().equals(".gif") ||fileType.toLowerCase().equals(".bmp") || fileType.toLowerCase().equals(".png")
                 || fileType.toLowerCase().equals(".tif")||fileType.toLowerCase().equals(".jpeg")){
                 
                 base+="\\Images\\";
                
                 }else{
                
                 base+="\\Bad\\" ;
                 }
             
              File  newFile = new File(base+file.getName());
            System.out.println(newFile);
            System.out.println(file);
              file.write(newFile);
              
              base = request.getSession().getServletContext().getRealPath("")+"\\admin\\upload";
             
          }
         
         
         
       }
 
         }
  
     
        }catch (Exception e) {
     // TODO: handle exception
        e.getMessage();
     }
    out.flush();
    out.close();
    response.sendRedirect("uploadSucess.jsp");
   }

  
  
  
}

由于我还没把代码分层好,所以都写在servlet拉,上面代码中特别注意的是:item.isFormField()这个方法,当时我一直以为这个方法时只要得文件信息这个方法就为true值,其实不然,这个方法时判断得到的数据类型是否是普通的表单数据类型,在此,我们的File不是普通的表单数据提交,所以返回值是false,这样在下面判断表单中是否有file文件就可以啦


在web。xml中配置servlet就不要多讲啦吧
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    AspUpload 组件上传 安装方法及其Demo(全)

    接下来,我们将详细讨论AspUpload组件的安装方法以及如何使用它创建一个简单的上传示例。 **安装AspUpload组件** 1. **下载组件**:首先,你需要从官方网站或其他可信来源下载AspUpload组件的安装包。确保选择与你...

    带进度条的无组件上传

    无组件上传带真实进度条 其中 upload.asp为核心代码,除非特殊需要,一般不需要修改 demo.htm是演示无刷新进度条(IE5.5+支持) demo.asp为处理demo.asp上传的文件,因为演示需要,在Demo.asp中仅仅上传,不作保存...

    文件上传组件 Uploadify-3.1-Demo实例详解

    Uploadify是一款功能强大且易于使用的文件上传组件,它通过Flash技术实现,能够帮助开发者在Web应用中轻松实现文件上传功能。本篇内容将围绕Uploadify 3.1版本进行详细介绍,并提供一个完整的示例代码来帮助理解其...

    UpLoadFile MVC完整Demo支持断点续传

    【标题】"UpLoadFile MVC完整Demo支持断点续传" 涉及到的关键技术主要是文件上传和断点续传,在MVC框架下实现。MVC(Model-View-Controller)是微软提出的一种软件设计模式,常用于构建Web应用程序。在本Demo中,它...

    无组件上传带真实进度条.rar

    无组件上传带真实进度条 其中 upload.asp为核心代码,除非特殊需要,一般不需要修改 demo.htm是演示无刷新进度条(IE5.5 支持) demo.asp为处理demo.asp上传的文件,因为演示需要,在Demo.asp中仅仅上传,不作...

    小程序复杂表单含文件上传demo.rar

    本资源“小程序复杂表单含文件上传demo.rar”提供了一个全面展示如何在小程序中实现复杂表单提交功能,包括表单字段验证、错误提示以及多文件上传与个数限制的示例。以下将详细讲解这些关键知识点。 首先,表单是...

    利用WCF实现文件上传源码

    **WCF(Windows Communication Foundation)**是微软.NET框架下的一个组件,它提供了一种用于创建分布式应用程序的强大且灵活的方式。WCF集成了多种通信技术,如HTTP、TCP、 Named Pipe等,使得服务间的交互变得更加...

    Asp无组件上传带进度条 1.0

    Asp无组件上传带进度条 1.0 无组件上传带真实进度条 其中 upload.asp为核心代码,除非特殊需要,一般不需要修改 demo.htm是演示无刷新进度条(IE5.5+支持) demo.asp为处理demo.asp上传的文件,因为演示需要,在...

    Asp无组件上传带进度条

    总的来说,实现ASP无组件上传带进度条需要结合前端和后端的技能,包括HTML5的新特性、JavaScript/Ajax的使用、ASP的文件处理以及数据库操作。这个过程中涉及到的技术点丰富多样,不仅考验开发者对多语言的熟练度,还...

    无组件上传带真实进度条

    无组件上传带真实进度条 其中 upload.asp为核心代码,除非特殊需要,一般不需要修改 demo.htm是演示无刷新进度条(IE5.5+支持) demo.asp为处理demo.asp上传的文件,因为演示需要,在Demo.asp中仅仅上传,不作保存...

    ASP无组件上传

    无组件上传带真实进度条 &lt;br&gt;其中 upload.asp为核心代码,除非特殊需要,一般不需要修改 demo.htm是演示无刷新进度条(IE5.5+支持) demo.asp为处理demo.asp上传的文件,因为演示需要,在Demo.asp中仅仅...

    多图片上传和取消上传(基于框架)

    关于“diyUpload”这个文件,可能包含了一个自定义上传组件的实现,比如使用Vue或React等前端框架编写。在分析这个组件时,我们需要注意其如何处理文件选择、状态管理、异步上传和取消操作等方面。 总之,实现多...

    在Struts2中使用Uploadify组件上传文件

    ### 在Struts2中使用Uploadify组件上传文件 #### 一、Uploadify简介与特性 Uploadify是一款基于jQuery的文件上传插件,以其强大的功能和优秀的用户体验受到开发者们的青睐。它利用Flash技术实现异步文件上传,使得...

    小程序上传视频组件

    【小程序上传视频组件】是微信小程序中用于实现用户在应用内录制并上传视频的功能模块。在小程序开发中,为了提供丰富的交互体验,开发者通常需要集成这样的组件,让用户能够方便地分享自己的生活瞬间或者进行各种...

    上传文件 commons-fileupload-1.1.jar jquery.ajaxfileupload.js 以及demo

    至于`uploadFile`,这可能是指一个包含实际文件上传示例的目录或者文件,它可能包含HTML、CSS、JavaScript代码,展示了如何使用这两个组件来实现文件上传功能。学习和理解这些示例代码,可以帮助开发者快速掌握文件...

    VB上传本地文件到服务器

    1. **文件选择组件**:在VB应用程序中,你可以使用`OpenFileDialog`控件让用户选择要上传的本地文件。该控件允许用户浏览文件系统并选择一个或多个文件。例如: ```vb Dim openFileDialog1 As New OpenFileDialog ...

    微信小程序学习用demo:相册:上传本地图片生成列表

    在微信小程序中实现相册功能,通常包括图片选择器的使用、本地图片的获取、上传到服务器以及在列表中展示。开发者可以使用`wx.chooseImage`接口让用户选择图片,`wx.getImageInfo`获取图片信息,`wx.saveFile`保存...

    struts2实现文件上传功能

    在Struts2中实现文件上传,主要涉及到以下几个核心组件和步骤: 1. **配置Struts2**:首先,你需要在`struts.xml`配置文件中启用Struts2的文件上传支持。这通常通过添加`&lt;constant&gt;`标签并设置`struts.multipart....

    c++ gsoap webservice文件传送demo

    总结,本示例“c++ gsoap webservice文件传送demo”展示了如何在Windows 7下,使用Visual C++和gSOAP库实现Web服务的文件传输。通过理解gSOAP的工作原理和API,以及掌握客户端和服务端的实现细节,你可以创建自己的...

    flash上传文件,flex上传,无刷新上传,php上传,含源码

    "demo.php"和"UploadFile.php"是PHP脚本文件,它们负责接收前端Flash上传的文件,进行合法性检查,如文件类型、大小限制,然后将文件保存到服务器指定目录。PHP的`$_FILES`全局变量用于获取上传文件的信息,`move_...

Global site tag (gtag.js) - Google Analytics