§http://www-900.ibm.com/developerWorks/java/fileup/index.shtml

解决方案 »

  1.   

    用JavaBean实现文件上载请求分析 
      要实现文件上载,我们必须先了解上载文件的HTTP请求。下面这个简单的应用示范了如何上载文件以及把HTTP请求的原始数据写入文件。用文本编辑器查看该文件即可了解请求的格式,在此基础上我们就可以提取出上载文件的名字、文件内容以及原本混合在一起的其他信息。 
      这个简单的应用是开发真正文件上载JavaBean的准备工作。它由三个文件构成:HTML文件main.html,JSP页面Jsp1.jsp,JavaBean文件SimpleBean.java。 
      main.html提供一个表单,用户从这里选择文件并把文件上载到服务器。main.html的代码如下: 
    <html> 
    <head> 
    <title>文件上载</title> 
    </head> 
    <body> 
    <form action="jsp1.jsp" enctype="MULTIPART/FORM-DATA" method=post> 
    作者: <input type="text" name="author" /> 
    <br /> 
    公司: <input type="text" name="company" /> 
    <br /> 
    选择要上载的文件 <input type="file" name="filename" /> 
    <br /> 
    <input type="submit" value="上载" /> 
    </form> 
    </body> 
    </html> 
      可以看到,<form>标记有一个enctype属性,属性值是"MULTIPART/FORM-DATA"。包括提交按钮在内,表单里面共有4个输入元素。前面两个输入元素是普通的text元素,即author和company。第三个输入元素的type属性是file,这个输入元素就是用来选择文件的元素。 
      表单的action属性值是Jsp1.jsp,这意味着请求(包括上载的文件)将发送给Jsp1.jsp文件。Jsp1.jsp简单地调用名为SimpleBean的JavaBean。 
    <jsp:useBean id="TheBean" scope="page" class="SimpleBean " /> 
    <% 
    TheBean.doUpload(request); 
    %> 
      下面是SimpleBean的实现代码: 
    import java.io.*; 
    import javax.servlet.http.HttpServletRequest; 
    import javax.servlet.http.HttpServletResponse; 
    import javax.servlet.ServletInputStream; 
      
    public class FileUploadBean { 
      
    public void doUpload(HttpServletRequest request) throws 
    IOException { 
    PrintWriter pw = new PrintWriter( 
    new BufferedWriter(new FileWriter("Demo.out"))); 
    ServletInputStream in = request.getInputStream(); 
      
    int i = in.read(); 
    while (i != -1) { 
    pw.print((char) i); 
    i = in.read(); 

    pw.close(); 


    这个JavaBean把HttpServletRequest对象的表单原始数据写入Demo.out文件。应用的用户界面由main.html文件提供,如下图所示。 
     我们选择上载的文件是abisco.html。选择上载HTML文件是为了便于观察上载后的格式,因为HTML文件本质上是文本文件,我们可以方便地浏览其内容。abisco.html文件的内容如下: 
    <html> 
    <head> 
    <title>Abisco</title> 
    </head> 
    </html> 
      点击“上载”按钮之后,表单就发送给了Jsp1.jsp文件,一起发送的还有abisco.html文件。Jsp1.jsp文件不会向浏览器发送任何应答内容,但它会生成一个Demo.out文件。 
      打开Demo.out文件,我们可以看到如下内容: 
    -----------------------------7d15340138 
    Content-Disposition: form-data; name="Author" 
      
    A. Christie 
    -----------------------------7d15340138 
    Content-Disposition: form-data; name="Company" 
      
    Abisco 
    -----------------------------7d15340138 
    Content-Disposition: form-data; name="Filename"; filename="C:\123data\abisco.html" 
    Content-Type: text/html 
      
    <html> 
    <head> 
    <title>Abisco</title> 
    </head> 
    </html> 
    -----------------------------7d15340138-- 
      可以看到,HTTP请求体内包含了所有的表单输入,包括上载的文件。这些输入数据的分隔由一个分隔符实现。分隔符由一系列的“-”字符和一个随机数字构成。在上面的例子中,分隔符为“-----------------------------7d15340138”。最后一个分隔符结束请求体,这个分隔符的后面多出两个“-”符号。 
      对于非文件类型的输入数据,分隔符后面跟着下面这行内容:Content-Disposition: form-data; name=inputName。其中inputName是表单元素的名字。例如:Content-Disposition: form-data; name="Author"。在这行内容的后面,紧跟着两个连续的回车换行符和表单元素值。 
      而对于文件型输入域,分隔符的后面有两行内容。第一行内容包含输入元素的名字以及上载文件在客户端的完整路径,如上例中这行内容是“Content-Disposition: form-data; name="Filename"; filename="C:\123data\abisco.html"”。这行内容指出文件输入元素的名字是filename,文件的路径是“C:\123data\abisco.html”。注意Windows浏览器会设置文件路径,而Unix/Linux以及Mac浏览器只发送文件名字。 
      第二行包含了文件的内容类型,因此它的具体内容和上载的文件有关。本例中第二行的内容是“Content-Type: text/html”。 
      和非文件输入元素一样,文件内容在两个连续的回车换行符之后正式开始。 
      

  2.   

    谢谢!jiangqi(远木--远方的木头) 
    马上试试!OK就给分!
      

  3.   

    谢谢!jiangqi(远木--远方的木头) 
    马上试试,OK就给分!