Java实现文件上传的方法

本文实例为大家分享了Java实现文件上传的具体代码,具体内容如下

1、java代码:

package com.github.reston.servlet;

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

import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
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 org.apache.commons.io.IOUtils;

@WebServlet("/AjaxUpload")
public class AjaxUpload extends HttpServlet{
 @Override
 public void init(ServletConfig config) throws ServletException{
  // TODO Auto-generated method stub
  super.init(config);
 }

 @Override
 protected void service(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
  response.setContentType("text/html");
  request.setCharacterEncoding("UTF-8");
  boolean isMultipart=ServletFileUpload.isMultipartContent(request);

  String basePath=getServletContext().getRealPath("/upload");
  File baseDirectory=new File(basePath);
  String filename="";
  long start=0;
  if(!baseDirectory.isDirectory()) baseDirectory.mkdirs();
  if(isMultipart){
   try{
    FileItemFactory factory=new DiskFileItemFactory();
    ServletFileUpload upload=new ServletFileUpload(factory);
    @SuppressWarnings("unchecked") List<FileItem> fileItems=upload.parseRequest(request);
    for(FileItem i:fileItems){
     if(i.isFormField()){
      String name=i.getFieldName();
      String value=i.getString();
      if(name.equals("start"))start=Long.parseLong(i.getString());
     }
    }
    for(FileItem item:fileItems){
     if(item.isFormField()) continue;
     filename=item.getFieldName();
     if(mkdir(basePath)){
      File fileonserver=createFile(basePath,filename);
      if(fileonserver.length()==0){
       FileOutputStream fos=new FileOutputStream(fileonserver,true);
       IOUtils.copy(item.getInputStream(),fos);
      }
      if(start>0){
       FileOutputStream fos=new FileOutputStream(fileonserver,true);
       IOUtils.copy(item.getInputStream(),fos);
      }
      PrintWriter pw=response.getWriter();
      pw.write("{\"length\":\""+fileonserver.length()+"\"}");
      pw.flush();
     }
    }
   }catch(Exception e){
   }
  }
 }

 private File createFile(String path,String name) throws IOException{

  File tmp=new File(path,name);
  if(!tmp.exists()){
   tmp.createNewFile();
  }
  return tmp;
 }

 private boolean mkdir(String path){
  boolean result=true;
  File tmp=new File(path);
  if(!tmp.isDirectory()){
   result=tmp.mkdirs();
  }
  return result;
 }
}

2、java代码:

var ajaxupload = function(e) {
 /**
  * e url method data success error
  */
 var xmlhttprequest;
 if (window.XMLHttpRequest) {
  xmlhttprequest = new XMLHttpRequest();
  if (xmlhttprequest.overrideMimeType) {
   xmlhttprequest.overrideMimeType("text/xml");
  }
 } else if (window.ActiveXObject) {
  var activeName = [ "MSXML2.XMLHTTP", "Microsoft.XMLHTTP" ];
  for (var i = 0; i < activeName.length; i++) {
   try {
    xmlhttprequest = new ActiveXObject(activeName[i]);
    break;
   } catch (e) {
    return;
   }
  }
 }
 if (xmlhttprequest == undefined || xmlhttprequest == null) {
  alert("XMLHttpRequest对象创建失败!!");
  return;
 } else {
  this.xmlhttp = xmlhttprequest;
 }

 var file = document.getElementById(e.id);
 if (this.xmlhttp != undefined && this.xmlhttp != null) {
  e.method = e.method.toUpperCase();
  if (e.method != "GET" && e.method != "POST") {
   alert("HTTP的请求方法必须为GET或POST!!!");
   return;
  }
  if (e.url == null || e.url == undefined) {
   e.alert("HTTP的请求地址必须设置!");
   return;
  }
 }

 this.xmlhttp.onreadystatechange = function() {
  if (this.readyState == 4) {
   if (this.status == 200) {
    var responseText = this.responseText;
    var responseXML = this.reponseXML;
    if (e.success == undefined || e.success == null) {
     alert("没有设置处理数据正确返回的方法");
     alert("返回的数据:" + responseText);
    } else {
     e.success(responseText, responseXML);
    }
   } else {
    if (e.error == undefined || e.error == null) {
     alert("没有设置处理数据返回失败的处理方法!");
     alert("HTTP的响应码:" + this.status + ",响应码的文本信息:" + this.statusText);
    } else {
     e.error(this.status, this.statusText);
    }
   }
  }
 }

// var formhtm="<form id='output' enctype='multipart/form-data' ></form>";

 var filename = getFileName(e.id);
 this.xmlhttp.open(e.method, e.url, true);
 var data = new FormData(document.getElementById("output"));
 data.append("name", filename);
 data.append("start", e.data.start);
 data.append(filename, document.getElementById(e.id).files[0].slice(e.data.start, getFileSize(e.id)));
 this.xmlhttp.send(data);
}

function getFileName(id) {
 var path = document.getElementById(id).value
 var pos1 = path.lastIndexOf('/');
 var pos2 = path.lastIndexOf('\\');
 var pos = Math.max(pos1, pos2);
 return path.substring(pos + 1);
}

function getFileSize(id) {
 return document.getElementById(id).files[0].size;
}

3、html代码:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="test.js"></script>

</head>
<body>

 <input type="file" name="upload" id="upload" value="上传"/><span>请选择要上传的文件(小于1G)</span>
 <input type="button" value="上传" onclick="test();"/>
<form id="output" enctype="multipart/form-data" ></form>
 <script>

 function test(){
  ajaxupload({
  id : "upload",
  url : "/PCC/reston/AjaxUpload",
  method : "POST",
  data : {start:0},
  success : function(e) {
   var l=JSON.parse(e).length;
   ajaxupload({
    id : "upload",
    url : "/PCC/reston/AjaxUpload",
    method : "POST",
    data : {start:l},
    success : function(e) {
    },
    error : function(e) {
     console.log(e);
    }
   });
  },
  error : function(e) {
   console.log(e);
  }
 });

 }

 </script>
</body>

</html>

以上就是本文的全部内容,希望对大家学习java程序设计有所帮助。

(0)

相关推荐

  • java基于servlet实现文件上传功能解析

    最近项目需要做一个文件上传功能,做完了分享下,顺带当做笔记. 上传功能用后台用java实现,前端主要是js的ajax实现.后台还加入定时删除临时文件. 效果如图 首先是上传功能的主要类,下面是代码 package util.upload; import java.io.File; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Iterat

  • JavaEE中struts2实现文件上传下载功能实例解析

    本文实例为大家分享了struts2实现文件上传下载的具体实现代码,供大家参考,具体内容如下 一.文件上传 struts提交的文件组件上传, 前台: 1).提交方式POST 2).表单类型 multipart/form-data 3).input type=file 后台: Apache提供的FileUpload组件 核心类: FileItemFactory FileItem的工厂 ServletFileUpload servlet 中的文件上传的核心类 FileItem 封装了上传的表单文件项的

  • JavaWeb实现文件上传下载功能实例解析

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用Servlet获取上传文件的输入流然后再解析里面的请求参数是比较麻烦,所以一般选择采用apache的开源工具common-fileupload这个文件上传组件.这个common-fileupload上传组件的jar包可以去apache官网上面下载,也可以在struts的lib文件夹下面找到,stru

  • JavaWeb中struts2实现文件上传下载功能实例解析

    在做B/S系统时,通常会涉及到上传文件和下载文件,在没接struts2框架之前,我们都是使用apache下面的commons子项目的FileUpload组件来进行文件的上传,但是那样做的话,代码看起来比较繁琐,而且不灵活,在学习了struts2后,struts2为文件上传下载提供了更好的实现机制,在这里我分别就单文件上传和多文件上传的源代码进行一下讲解,这里需要导入文件下载上传的两个jar文件,一个是commons-fileupload-1.2.2.jar,另一个是commons-io-2.0.

  • java实现FTP文件上传与文件下载

    本文实例为大家分享了两种java实现FTP文件上传下载的方式,供大家参考,具体内容如下 第一种方式: package com.cloudpower.util; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import sun.net.TelnetInputStream; import sun.net.TelnetO

  • JavaWeb文件上传下载功能深入分析(二)

    接着上一篇叙述: 二.文件上传与下载 Struts2开发的三板斧,页面jsp-配置文件struts2.xml--还有动作类Action 文件上传前提: form表单的method必须是post form表单的enctype必须是multipart/form-data 提供type="file"的上传输入域 Struts 对文件上传的支持的一些规则 1.单文件上传 开发步骤: 1).在WEB-INF/lib下加入commons-fileupload-1.2.1.jar.commons-i

  • 简述Java异步上传文件的三种方式

    本文为大家分享了三种Java异步上传文件方式,供大家参考,具体内容如下 用第三方控件,如Flash,ActiveX等浏览器插件上传. 使用隐藏的iframe模拟异步上传. 使用XMLHttpRequest2来实现异步上传. 第一种使用浏览器插件上传,需要一定的底层编码功底,在这里我就不讲了,以免误人子弟,提出这点大家可以自行百度. 第二种使用隐藏的iframe模拟异步上传.为什么在这里说的是模拟呢?因为我们其实是将返回结果放在了一个隐藏的iframe中,所以才没有使当前页面跳转,感觉就像是异步操

  • 基于Java中两种jersey文件上传方式

    本文将带领大家使用基于JAX-RS REST风格的实现Jersey来上传文件到服务器制定的文件夹,如果是图片并读取显示出该图片. 准备工作:准备一个form表单,有两个字段,一个是type="file"和type="text",并且表单需要使用POST方式提交.注意改表单需要使用multipart/form-data.该项目使用netbeans8.0和glassfish4.0开发和运行.并且使用maven管理该工程:需要在您的C盘建立一个文件夹,用来存储上传的文件.

  • java实现动态上传多个文件并解决文件重名问题

    本文分为两大方面进行讲解: 一.java实现动态上传多个文件 二.解决文件重命名问题java 供大家参考,具体内容如下 1.动态上传多个文件 <form name="xx" action="<c:url value='/Up3Servlet'/>" method="post" enctype="multipart/form-data"> <table id="tb" borde

  • java中struts2实现简单的文件上传与下载

    一.Struts2文件上传  Struts2的文件上传实现非常简单,只需要简单几步就可完成: 注意: (1)文件上传的struts2标签为:<s:file name="" label="上传"/> (2)文件上传的前提是表单属性method="post" enctype="multipart/form-data"; (3)web应用中必须包含common-fileupload.jar和common-io.jar,因

随机推荐