当前位置: 移动技术网 > IT编程>开发语言>Java > java基于servlet的文件异步上传

java基于servlet的文件异步上传

2019年07月22日  | 移动技术网IT编程  | 我要评论

第一滴血5:背水一战,大连天气预报查询一周,33999

在这里使用了基于servlet的文件异步上传,好了废话不多说,直接上代码了。。。

package com.future.zfs.util;

import java.io.file;
import java.io.ioexception;
import java.io.printwriter;
import java.util.iterator;
import java.util.list;

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.fileuploadexception;
import org.apache.commons.fileupload.fileuploadbase.sizelimitexceededexception;
import org.apache.commons.fileupload.disk.diskfileitemfactory;
import org.apache.commons.fileupload.servlet.servletfileupload;

@suppresswarnings("serial")
public class fileuploadservlet extends httpservlet {

  final long max_size = 10 * 1024 * 1024;// 设置上传文件最大为 10m
  // 允许上传的文件格式的列表
  final string[] allowtype = new string[] {"jpg","jpeg","gif","txt","doc","docx","mp3","wma","m4a","xls"};

  public fileuploadservlet() {
    super();
  }

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

  @override
  protected void service(httpservletrequest request, httpservletresponse response)
      throws servletexception, ioexception {
    response.setcontenttype("text/html");
    // 设置字符编码为utf-8, 这样支持汉字显示
    response.setcharacterencoding("utf-8");

    // 实例化一个硬盘文件工厂,用来配置上传组件servletfileupload
    diskfileitemfactory dfif = new diskfileitemfactory();
    dfif.setsizethreshold(4096);// 设置上传文件时用于临时存放文件的内存大小,这里是4k.多于的部分将临时存在硬盘
    dfif.setrepository(new file(request.getrealpath("/")
        + "uploadtemp"));// 设置存放临时文件的目录,web根目录下的uploadtemp目录
    // 用以上工厂实例化上传组件
    servletfileupload sfu = new servletfileupload(dfif);
    // 设置最大上传尺寸
    sfu.setsizemax(max_size);

    printwriter out = response.getwriter();
    // 从request得到 所有 上传域的列表
    list filelist = null;
    try {
      filelist = sfu.parserequest(request);
    } catch (fileuploadexception e) {// 处理文件尺寸过大异常
      if (e instanceof sizelimitexceededexception) {
        out.println("{message:'文件尺寸超过规定大小:"+max_size+"字节'}");
        return;
      }
      e.printstacktrace();
    }
    // 没有文件上传
    if (filelist == null || filelist.size() == 0) {
      out.println("{message:'请选择上传文件'}");
      return;
    }
    // 得到所有上传的文件
    iterator fileitr = filelist.iterator();
    // 循环处理所有文件
    while (fileitr.hasnext()) {
      fileitem fileitem = null;
      string path = null;
      long size = 0;
      // 得到当前文件
      fileitem = (fileitem) fileitr.next();
      // 忽略简单form字段而不是上传域的文件域(<input type="text" />等)
      if (fileitem == null || fileitem.isformfield()) {
        continue;
      }
      // 得到文件的完整路径
      path = fileitem.getname();
      // 得到文件的大小
      size = fileitem.getsize();
      if ("".equals(path) || size == 0) {
        out.println("{message:'请选择上传文件'}");
        return;
      }

      // 得到去除路径的文件名
      string t_name = path.substring(path.lastindexof("\\") + 1);
      // 得到文件的扩展名(无扩展名时将得到全名)
      string t_ext = t_name.substring(t_name.lastindexof(".") + 1);
      // 拒绝接受规定文件格式之外的文件类型
      int allowflag = 0;
      int allowedextcount = allowtype.length;
      for (; allowflag < allowedextcount; allowflag++) {
        if (allowtype[allowflag].equals(t_ext))
          break;
      }
      if (allowflag == allowedextcount) {
        string message = "";
        for (allowflag = 0; allowflag < allowedextcount; allowflag++){
          message+="*." + allowtype[allowflag]
                        + " ";
        }
        out.println("{message:'请上传以下类型的文件"+message+"'}");
        return;
      }

      long now = system.currenttimemillis();
      // 根据系统时间生成上传后保存的文件名
      string prefix = string.valueof(now);
      // 保存的最终文件完整路径,保存在web根目录下的upload目录下
      string u_name = request.getrealpath("/") + "upload/"
          + prefix + "." + t_ext;
      //原来的文件名
      path=request.getrealpath("/") + "upload/"+path;
      try {
        // 保存文件
        fileitem.write(new file(path));
        response.setstatus(200);
        out.println("{message:\"文件上传成功. 已保存为: " + prefix + "." + t_ext
            + " 文件大小: " + size + "字节\"}");
      } catch (exception e) {
        e.printstacktrace();
      }

    }
  }
}

web.xml

<servlet>
    <servlet-name>fileuploadservlet</servlet-name>
    <servlet-class>com.future.zfs.util.fileuploadservlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>fileuploadservlet</servlet-name>
    <url-pattern>/fileuploadservlet</url-pattern>
  </servlet-mapping>

上传页面

<%@ page language="java" contenttype="text/html; charset=utf-8"
  pageencoding="utf-8"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
  <head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8">
    <title>insert title here</title>
    <script type="text/javascript" src="js/jquery.js"></script>
    <script type="text/javascript" src="js/ajaxfileupload.js"></script>
    <script type="text/javascript">
  function ajaxfileupload()
  {
    
    $("#loading")
    .ajaxstart(function(){
      $(this).show();
    })//开始上传文件时显示一个图片
    .ajaxcomplete(function(){
      $(this).hide();
    });//文件上传完成将图片隐藏起来
    
    $.ajaxfileupload
    (
      {
        url:'fileuploadservlet',//用于文件上传的服务器端请求地址
        secureuri:false,//一般设置为false
        fileelementid:'file',//文件上传空间的id属性 <input type="file" id="file" name="file" />
        datatype: 'json',//返回值类型 一般设置为json
        success: function (data, status) //服务器成功响应处理函数
        {
          //alert(data.message);//从服务器返回的json中取出message中的数据,其中message为在struts2中定义的成员变量
          $('#myspan').html(data.message);
          if(typeof(data.error) != 'undefined')
          {
            if(data.error != '')
            {
              //alert(data.error);
              $('#myspan').html(data.message);
            }else
            {
              //alert(data.message);
              $('#myspan').html(data.message);
            }
          }
        },
        error: function (data, status, e)//服务器响应失败处理函数
        {
          //alert(e);
          $('#myspan').html(e);
        }
      }
    )
    
    return false;

  }
  </script>
  </head>
  <body>
    <img src="images/loading.gif" id="loading" style="display: none;">
    <span style="color: red;" id="myspan"></span><br/>
    <input type="file" id="file" name="file" />
    <br />
    <input type="button" value="上传" onclick="return ajaxfileupload();">
    <a href="filedownloadservlet?filename=通讯录.xls">哈哈,测试文件下载</a>
  </body>
</html>

需要注意的是:在使用ajaxfileupload基于servlet上传时需要设置response.setcontenttype("text/html");尽管datatype: 'json'设置为json仍要设置response.setcontenttype("text/html");否则获取不到服务器端返回的数据以及会弹出一个对话框。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网