JSP实现快速上传文件的方法_JSP编程

本文实例讲述了JSP实现快速上传文件的方法。分享给大家供大家参考。具体如下:

这里演示JSP不使用第三方库,实现快速上传文件的功能

1. FileUpload.java:

package FileUpload;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import javax.servlet.ServletInputStream;
/**
 *
 */
/**
 * @author Qch
 *
 */
public class FileUpload
{
  ServletInputStream in=null;
  String fpath="C://";
  public FileUpload()
  {
    fpath="C://";
    in=null;
  }
  public void setInputStream(ServletInputStream in)
  {
    this.in=in;
  }
  public void setFpath(String p)
  {
    this.fpath=p;
  }
  public String getFpath()
  {
    return fpath;
  }
  public String getParameter()
  {
    String r=null;
    try
    {
      r=getParameter(in);
    }
    catch (Exception e)
    {
      e.printStackTrace();
    }
    return r;
  }
  public long getFileUpload()
  {
    long r=-1;
    try
    {
      r=getFileUpload(in,fpath);
    }
    catch (Exception e)
    {
      e.printStackTrace();
    }
    return r;
  }
  public String getParameter(ServletInputStream in)// 只能按顺序提取
      throws Exception
  {
    int l = 0;
    byte[] b = new byte[1024];
    l = in.readLine(b, 0, b.length);// 依次是读取属性的开始符、名称、属性值的类型、属性的值
    String si = new String(b);
    if (si.startsWith("----------------------------"))
    {// 表示是从开始符开始读,否则应为刚读取文件后的一个属性,此时应少读一次
      l = in.readLine(b, 0, b.length);
    }
    l = in.readLine(b, 0, b.length);
    l = in.readLine(b, 0, b.length);
    String value = new String(b, 0, l);
    return value;
  }
  public long getFileUpload(ServletInputStream in, String fpath)// 需要提供输入流和存储路径
      throws Exception
  {
    // out.println("文件信息:<br>");
    long begin = System.currentTimeMillis();// 传送时间计时开始
    int l = 0;
    byte[] b = new byte[1024];
    l = in.readLine(b, 0, b.length);
    String sign = new String(b, 0, l);// eg.-----------------------------7d9dd29630a34
    l = in.readLine(b, 0, b.length);
    String info = new String(b, 0, l);// eg.Content-Disposition:form-data;
    // name="file";
    l = in.readLine(b, 0, b.length);
    // String type=new
    // String(b,0,l);//eg.Content-Type:application/octet-stream(程序文件)
    l = in.readLine(b, 0, b.length);
    // String nulll=new String(b,0,l);//此值应为空
    int nIndex = info.toLowerCase().indexOf("filename=\"");
    int nLastIndex = info.toLowerCase().indexOf("\"", nIndex + 10);
    String filepath = info.substring(nIndex + 10, nLastIndex);
    int na = filepath.lastIndexOf("\\");
    String filename = filepath.substring(na + 1);
    // out.println("文件绝对路径:"+filepath+"<br>");
    // out.println("文件名:"+filename+"<br><br>");
    String path=fpath + filename;
    File fi = new File(path);// 建立目标文件
    if (!fi.exists()&&!fi.createNewFile())
      return -2;
    BufferedOutputStream f = new BufferedOutputStream(new FileOutputStream(
        fi));
    while ((l = in.readLine(b, 0, b.length)) > 0)
    {
      if (l == sign.length())
      {
        String sign1 = new String(b, 0, sign.length());
        // out.println(sign1+"<br>");
        if (sign1.startsWith(sign))// 比对是否文件已传完
          break;
      }
      f.write(b, 0, l);
      f.flush();
    }
    f.flush();
    f.close();
    long end = System.currentTimeMillis();// 传送时间计时结束
    // out.println("上传文件用时:"+(end-begin)+"毫秒<br>");
    return end - begin;
  }
}

2. submitFile.jsp:

<%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
<%
  String path = request.getContextPath();
  String basePath = request.getScheme() + "://"
      + request.getServerName() + ":" + request.getServerPort()
      + path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>My JSP 'submitFile.jsp' 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="styles.css">
  -->
    <script language="javascript">
      function check()
      {
        if (document.form2.name.value==""){
          alert("姓名不能为空!!");
          document.form2.name.focus();
          return false;
        }
        if (document.form2.file.value==""){
          alert("文件不能为空!!");
          return false;
        }
        return true;
      }
    </script>
  </head>
  <body>
    <br>
    <form method="post" name="form2" enctype="MULTIPART/FORM-DATA"
      action="AnswerFile.jsp">
      <br>
      <p align="center">
         
        <br>
      </p>
      <table width="530" border="1" bgcolor="#c0c0c0" align="center"
        height="91">
        <tbody>
          <tr>
            <td valign="top" align="right">
              姓名
              <br>
            </td>
            <td valign="top">
              <input type="text" name="name">
            </td>
          </tr>
          <tr>
            <td align="right">
                文件
            </td>
            <td align="left">
               
              <input type="file" name="file">
            </td>
          </tr>
          <tr>
            <td valign="top" align="right">
              文件类型
              <br>
            </td>
            <td valign="top" align="left">
              <select size="1" name="leixing">
                <option selected value="作业">
                  作业
                </option>
                <option value="课程设计">
                  课程设计
                </option>
                <option value="论文">
                  论文
                </option>
              </select>
            </td>
          </tr>
          <tr>
            <td align="right">
              <input type="Submit" value="上传" name="button2" onclick="return(check());">
            </td>
            <td align="left">
               
              <input type="reset" value="重置" name="button3">
            </td>
          </tr>
        </tbody>
      </table>
      <p>
         
        <br>
        <br>
         
      </p>
    </form>
  </body>
</html>

3. AnswerFile.jsp:



<%@ page language="java" import="java.util.*,java.io.*"
  pageEncoding="GB18030"%>
<%
  String path = request.getContextPath();
  String basePath = request.getScheme() + "://"
      + request.getServerName() + ":" + request.getServerPort()
      + path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>My JSP 'AnswerFile.jsp' 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="styles.css">
  -->
  </head>
  <body>
    <jsp:useBean id="upload" scope="session" class="FileUpload.FileUpload"/>
    <jsp:setProperty name="upload" value="C://" property="fpath"/>
    <%
      ServletInputStream in = request.getInputStream();
      upload.setInputStream(in);
      String nam = upload.getParameter();
      out.println("姓名:" + nam + "<br><br>");
      long time = upload.getFileUpload();
      out.println("文件上传完毕,总共耗时:" + time + "毫秒<br>");
      String leixing = upload.getParameter();
      out.println("文件类型:" + leixing + "<br>");
      in.close();
    %>
    <br>
    <div align="right">
      <a href="index.jsp">回到首页</a>
    </div>
  </body>
</html>

希望本文所述对大家的JSP程序设计有所帮助。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索jsp
上传文件
编程实现快速排序、编程实现快速排序算法、jsp实现文件上传、jsp上传图片 实现预览、jsp实现图片上传,以便于您获取更多的相关知识。

时间: 2024-10-24 08:14:24

JSP实现快速上传文件的方法_JSP编程的相关文章

jsp+ajax实现无刷新上传文件的方法_AJAX相关

本文实例讲述了jsp+ajax实现无刷新上传文件的方法.分享给大家供大家参考,具体如下: 列表页:selectaddress.jsp js页:ajax_edit.js jsp处理页:editaddress.jsp 上传工具类:UploadUtil.java 思想:由于安全问题,javascript操纵不了文件, 导致ajax不能动态上传文件,所以选择了iframe, 列表页把form表单提交到一个隐式的iframe里面,设置表单的属性 复制代码 代码如下: enctype='multipart/

php限制上传文件类型并保存上传文件的方法

 这篇文章主要介绍了php限制上传文件类型并保存上传文件的方法,涉及php针对上传文件的常用操作技巧,非常具有实用价值,需要的朋友可以参考下     本文实例讲述了php限制上传文件类型并保存上传文件的方法.分享给大家供大家参考.具体如下: 下面的代码演示了php中如何获取用户上传的文件,并限制文件类型的一般图片文件,最后保存到服务器 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 3

在Node.js中使用HTTP上传文件的方法

  这篇文章主要介绍了在Node.js中使用HTTP上传文件的方法,作者以windows下的visual studio作为操作node的环境,推荐阅读!需要的朋友可以参考下 开发环境 我们将使用 Visual Studio Express 2013 for Web 作为开发环境, 不过它还不能被用来做 Node.js 开发.为此我们需要安装 Node.js Tools for Visual Studio. 装好后 Visual Studio Express 2013 for Web 就会转变成一

php限制上传文件类型并保存上传文件的方法_php技巧

本文实例讲述了php限制上传文件类型并保存上传文件的方法.分享给大家供大家参考.具体如下: 下面的代码演示了php中如何获取用户上传的文件,并限制文件类型的一般图片文件,最后保存到服务器 <?php $allowedExts = array("gif", "jpeg", "jpg", "png"); $extension = end(explode(".", $_FILES["file&qu

PHP文件上传判断file是否己选择上传文件的方法_php技巧

本文实例讲述了PHP文件上传判断file是否己选择上传文件的方法.分享给大家供大家参考.具体方法如下: 一个合格的程序员在实现数据入库中时我们都会有一些非常严密的过滤与数据规则,像我们文件上传时在前段要判断用户是否选择上传文件同时在后台也可判断是否有上传的文件,本文实例即对此做一较为深入的分析. 如下html代码所示: 复制代码 代码如下: <form action="?" method="post" enctype='multipart/form-data'

buffer-大家帮帮忙!我这个上传文件的方法为什么会限制文件的大小啊?文件超过一定的大小,上传就失败了!

问题描述 大家帮帮忙!我这个上传文件的方法为什么会限制文件的大小啊?文件超过一定的大小,上传就失败了! private void PostFile(string filename) { FileStream stream = new FileInfo(filename).OpenRead(); var shortfilename = Path.GetFileName(filename); HttpWebRequest request = (HttpWebRequest)HttpWebReques

技术-spring 3+hibernate 4+JSP 表单上传文件

问题描述 spring 3+hibernate 4+JSP 表单上传文件 我使用spring 3+hibernate 4+JSP表单来上传文件,application.XML文件如果配置oracleLobHandler启动时就会报Bean property 'lobHandler' is not writable or has an invalid setter method错误,如果不配置的话在保存时会保org.springframework.orm.hibernate3.support.Bl

jQuery Ajax使用FormData对象上传文件的方法_jquery

FormData对象,是可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单". 在 Mozilla Developer 网站 使用FormData对象 有详尽的FormData对象使用说明. 但上传文件部分只有底层的XMLHttpRequest对象发送上传请求,那么怎么通过jQuery的Ajax上传呢? 本文将介绍通过jQuery使用FormData对象上传文件. 使用<form>表单初始化FormData对象方式上传文件 HTM

jQuery Ajax方式上传文件的方法_AJAX相关

jQuery Ajax方式上传文件用到两个对象 第一个对象:FormData 第二个对象:XMLHttpRequest 目前新版的Firefox 与 Chrome 等支持HTML5的浏览器完美的支持这两个对象,但IE9尚未支持 FormData 对象,还在用IE6 ? 只能仰天长叹.... 有了这两个对象,我们可以真正的实现Ajax方式上传文件. 示例代码: <!DOCTYPE html> <html> <head> <title>Html5 Ajax 上传