Servlet实现文件上传,可多文件上传示例


Posted in Javascript onDecember 05, 2016

一、Servlet实现文件上传,需要添加第三方提供的jar包

下载地址:

1) commons-fileupload-1.2.2-bin.zip:  点击打开链接

2)  commons-io-2.3-bin.zip:    点击打开链接 

接着把这两个jar包放到 lib文件夹下:

Servlet实现文件上传,可多文件上传示例

二:文件上传的表单提交方式必须是POST方式,

编码类型:enctype="multipart/form-data",默认是 application/x-www-form-urlencoded

比如:

<form action="FileUpLoad"enctype="multipart/form-data"method="post">

三、举例:

1.fileupload.jsp

<%@ page language="java" import="javautil*" pageEncoding="UTF-8"%> 
<% 
String path = requestgetContextPath(); 
String basePath = requestgetScheme()+"://"+requestgetServerName()+":"+requestgetServerPort()+path+"/"; 
%> 
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 01 Transitional//EN"> 
<html> 
 <head> 
  <base href="<%=basePath%>"> 
   
  <title>My JSP 'fileuploadjsp' starting page</title> 
   
  <meta http-equiv="pragma" content="no-cache"> 
  <meta http-equiv="cache-control" content="no-cache"> 
  <meta http-equiv="expires" content="0">   
  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> 
  <meta http-equiv="description" content="This is my page"> 
  <!-- 
  <link rel="stylesheet" type="text/css" href="stylescss"> 
  --> 
 
 </head> 
  
 <body> 
   <!-- enctype 默认是 application/x-www-form-urlencoded --> 
   <form action="FileUpLoad" enctype="multipart/form-data" method="post" > 
     
        用户名:<input type="text" name="usename"> <br/> 
        上传文件:<input type="file" name="file1"><br/> 
       上传文件: <input type="file" name="file2"><br/> 
       <input type="submit" value="提交"/>     
   </form>     
 </body> 
</html>

2.实际处理文件上传的 FileUpLoad.java

package comservletfileupload; 
import javaioFile; 
import javaio*; 
import javaioIOException; 
import javaioPrintWriter; 
import javautilList;  
import javaxservletServletException; 
import javaxservlethttpHttpServlet; 
import javaxservlethttpHttpServletRequest; 
import javaxservlethttpHttpServletResponse; 
import orgapachecommonsfileuploadFileItem; 
import orgapachecommonsfileuploadFileUploadException; 
import orgapachecommonsfileuploaddiskDiskFileItemFactory; 
import orgapachecommonsfileuploadservletServletFileUpload; 
 
/** 
 * 
 * @author Administrator 
 * 文件上传 
 * 具体步骤: 
 * 1)获得磁盘文件条目工厂 DiskFileItemFactory 要导包 
 * 2) 利用 request 获取 真实路径 ,供临时文件存储,和 最终文件存储 ,这两个存储位置可不同,也可相同 
 * 3)对 DiskFileItemFactory 对象设置一些 属性 
 * 4)高水平的API文件上传处理 ServletFileUpload upload = new ServletFileUpload(factory); 
 * 目的是调用 parseRequest(request)方法 获得 FileItem 集合list , 
 *   
 * 5)在 FileItem 对象中 获取信息,  遍历, 判断 表单提交过来的信息 是否是 普通文本信息 另做处理 
 * 6) 
 *  第一种 用第三方 提供的 itemwrite( new File(path,filename) ); 直接写到磁盘上 
 *  第二种 手动处理  
 * 
 */ 
public class FileUpLoad extends HttpServlet { 
 
  public void doPost(HttpServletRequest request, HttpServletResponse response) 
      throws ServletException, IOException { 
     
    requestsetCharacterEncoding("utf-8"); //设置编码 
     
    //获得磁盘文件条目工厂 
    DiskFileItemFactory factory = new DiskFileItemFactory(); 
    //获取文件需要上传到的路径 
    String path = requestgetRealPath("/upload"); 
     
    //如果没以下两行设置的话,上传大的 文件 会占用 很多内存, 
    //设置暂时存放的 存储室 , 这个存储室,可以和 最终存储文件 的目录不同 
    /** 
     * 原理 它是先存到 暂时存储室,然后在真正写到 对应目录的硬盘上, 
     * 按理来说 当上传一个文件时,其实是上传了两份,第一个是以 tem 格式的 
     * 然后再将其真正写到 对应目录的硬盘上 
     */ 
    factorysetRepository(new File(path)); 
    //设置 缓存的大小,当上传文件的容量超过该缓存时,直接放到 暂时存储室 
    factorysetSizeThreshold(1024*1024) ; 
     
    //高水平的API文件上传处理 
    ServletFileUpload upload = new ServletFileUpload(factory); 
     
     
    try { 
      //可以上传多个文件 
      List<FileItem> list = (List<FileItem>)uploadparseRequest(request); 
       
      for(FileItem item : list) 
      { 
        //获取表单的属性名字 
        String name = itemgetFieldName(); 
         
        //如果获取的 表单信息是普通的 文本 信息 
        if(itemisFormField()) 
        {           
          //获取用户具体输入的字符串 ,名字起得挺好,因为表单提交过来的是 字符串类型的 
          String value = itemgetString() ; 
           
          requestsetAttribute(name, value); 
        } 
        //对传入的非 简单的字符串进行处理 ,比如说二进制的 图片,电影这些 
        else 
        { 
          /** 
           * 以下三步,主要获取 上传文件的名字 
           */ 
          //获取路径名 
          String value = itemgetName() ; 
          //索引到最后一个反斜杠 
          int start = valuelastIndexOf("\\"); 
          //截取 上传文件的 字符串名字,加1是 去掉反斜杠, 
          String filename = valuesubstring(start+1); 
           
          requestsetAttribute(name, filename); 
           
          //真正写到磁盘上 
          //它抛出的异常 用exception 捕捉 
           
          //itemwrite( new File(path,filename) );//第三方提供的 
           
          //手动写的 
          OutputStream out = new FileOutputStream(new File(path,filename)); 
           
          InputStream in = itemgetInputStream() ; 
           
          int length = 0 ; 
          byte [] buf = new byte[1024] ; 
           
          Systemoutprintln("获取上传文件的总共的容量:"+itemgetSize()); 
 
          // inread(buf) 每次读到的数据存放在  buf 数组中 
          while( (length = inread(buf) ) != -1) 
          { 
            //在  buf 数组中 取出数据 写到 (输出流)磁盘上 
            outwrite(buf, 0, length); 
             
          } 
           
          inclose(); 
          outclose(); 
        } 
      } 
       
       
       
    } catch (FileUploadException e) { 
      // TODO Auto-generated catch block 
      eprintStackTrace(); 
    } 
    catch (Exception e) { 
      // TODO Auto-generated catch block 
       
      //eprintStackTrace(); 
    } 
     
     
    requestgetRequestDispatcher("filedemojsp")forward(request, response); 
     
 
  } 
 
} 

System.out.println("获取上传文件的总共的容量:"+item.getSize());

3.filedemo.jsp

<%@ page language="java" import="javautil*" pageEncoding="UTF-8"%> 
<% 
String path = requestgetContextPath(); 
String basePath = requestgetScheme()+"://"+requestgetServerName()+":"+requestgetServerPort()+path+"/"; 
%> 
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 01 Transitional//EN"> 
<html> 
 <head> 
  <base href="<%=basePath%>"> 
   
  <title>My JSP 'filedemojsp' starting page</title> 
   
  <meta http-equiv="pragma" content="no-cache"> 
  <meta http-equiv="cache-control" content="no-cache"> 
  <meta http-equiv="expires" content="0">   
  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> 
  <meta http-equiv="description" content="This is my page"> 
  <!-- 
  <link rel="stylesheet" type="text/css" href="stylescss"> 
  --> 
 
 </head> 
  
 <body> 
   
  用户名:${requestScopeusename } <br/> 
  文件:${requestScopefile1 }<br/> 
  ${requestScopefile2 }<br/> 
  <!-- 把上传的图片显示出来 --> 
  <img alt="go" src="upload/<%=(String)requestgetAttribute("file1")%> " /> 
   
   
   
 </body> 
</html>

4结果页面:

Servlet实现文件上传,可多文件上传示例

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
iis6+javascript Add an Extension File
Jun 13 Javascript
JS+CSS实现分类动态选择及移动功能效果代码
Oct 19 Javascript
jquery自适应布局的简单实例
May 28 Javascript
angular+bootstrap的双向数据绑定实例
Mar 03 Javascript
详解vue 实例方法和数据
Oct 23 Javascript
jQuery简单实现对数组去重及排序操作实例
Oct 31 jQuery
anime.js 实现带有描边动画效果的复选框(推荐)
Dec 24 Javascript
微信小程序自定义组件之可清除的input组件
Jul 17 Javascript
JavaScript事件冒泡与事件捕获实例分析
Aug 01 Javascript
create-react-app安装出错问题解决方法
Sep 04 Javascript
angularJs中json数据转换与本地存储的实例
Oct 08 Javascript
如何在vue中使用HTML 5 拖放API
Jan 14 Vue.js
微信小程序 textarea 详解及简单使用方法
Dec 05 #Javascript
解析Javascript单例模式概念与实例
Dec 05 #Javascript
微信公众号  提示:Unauthorized API function 问题解决方法
Dec 05 #Javascript
深入理解jQuery()方法的构建原理
Dec 05 #Javascript
jQuery控制控件文本的长度的操作方法
Dec 05 #Javascript
浅析Ajax语法
Dec 05 #Javascript
jQuery的事件预绑定
Dec 05 #Javascript
You might like
星际玩家的三大定律
2020/03/04 星际争霸
php smarty模版引擎中变量操作符及使用方法
2009/12/11 PHP
CodeIgniter使用phpcms模板引擎
2013/11/12 PHP
PHP5.3新特性小结
2016/02/14 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
PDO::quote讲解
2019/01/29 PHP
js调试系列 断点与动态调试[基础篇]
2014/06/18 Javascript
网页下载文件期间如何防止用户对网页进行其他操作
2014/06/27 Javascript
一起学写js Calender日历控件
2016/04/14 Javascript
js+html获取系统当前时间
2017/11/10 Javascript
解决vue接口数据赋值给data没有反应的问题
2018/08/27 Javascript
微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例
2018/12/11 Javascript
js中async函数结合promise的小案例浅析
2019/04/14 Javascript
使用 Vue cli 3.0 构建自定义组件库的方法
2019/04/30 Javascript
JavaScript 装逼指南(js另类写法)
2020/05/10 Javascript
解决vue+elementui项目打包后样式变化问题
2020/08/03 Javascript
OpenLayers加载缩放控件使用方法详解
2020/09/25 Javascript
js禁止查看源文件屏蔽Ctrl+u/s、F12、右键等兼容IE火狐chrome
2020/10/01 Javascript
使用python统计文件行数示例分享
2014/02/21 Python
在Python中处理XML的教程
2015/04/29 Python
Django中间件拦截未登录url实例详解
2019/09/03 Python
django在保存图像的同时压缩图像示例代码详解
2020/02/11 Python
HTML5和以前HTML4的区别整理
2013/10/20 HTML / CSS
HTML5+Canvas+CSS3实现齐天大圣孙悟空腾云驾雾效果
2016/04/26 HTML / CSS
澳大利亚第一的设计师礼服租赁网站:GlamCorner
2017/08/13 全球购物
药学专业大学生自荐信
2013/09/28 职场文书
搞笑创意广告语
2014/03/17 职场文书
新闻发布会主持词
2014/03/28 职场文书
租房协议书范本
2014/04/09 职场文书
活动宣传策划方案
2014/05/23 职场文书
教师师德师风整改措施
2014/10/24 职场文书
党员作风建设整改方案
2014/10/27 职场文书
交警正风肃纪剖析材料
2014/10/29 职场文书
高中教师个人工作总结
2015/02/10 职场文书
详解Redis集群搭建的三种方式
2021/05/31 Redis
Python一些基本的图像操作和处理总结
2021/06/23 Python