1. 程式人生 > >javaweb-servlet學習筆記(4)

javaweb-servlet學習筆記(4)

這是一個servlet實現的上傳檔案的簡單栗子:

一、在上傳頁面需要注意兩點:

1.上傳檔案的method只能是post方式,get不能上傳檔案。 還需要加上enctype="multipart/form-data" 表示提交的資料是二進位制檔案。

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

2.需要提供type="file" 的欄位進行上傳。

upload.html頁面程式碼:

<!DOCTYPE html>
 
<meta http-equiv
="Content-Type" content="text/html; charset=UTF-8"> <form action="upload" method="post" enctype="multipart/form-data"> 使用者姓名:<input type="text" name="userName" /> <br> 選擇頭像 : <input type="file" name="filepath" /> <br> <input type="submit" value="上傳"> </form
>

二、準備上傳圖片的servlet類

1. 需要用到的jar包:commons-io-1.4.jar和commons-fileupload-1.2.2.jar,可在網上自行下載,放在WEB-INF/lib下。右鍵 project->properties->java build path->libaries->add external jars匯入jar包。

2. 提交的檔名有可能是重複的,我們用時間戳重新命名圖片。

3. 圖片會儲存在服務端的目錄下 e:/project/j2ee/web/uploaded,可以通過getRealPath獲取到的。

4. 根據臨時生成的檔名,建立一個html img元素,然後通過response返回瀏覽器。

注意:因為聲明瞭提交的是二進位制資料,所以對於type不是file的資料沒有辦法通過普通的方式獲取的,可以通過item.isFormField判斷是提交檔案還是普通欄位。當item.isFormField返回true的時候,就表示是常規欄位。通過item.getFieldName()和item.getString()就知道分別是哪個欄位,以及欄位的值了。

UploadServlet.java程式碼:

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.InputStream;
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.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
  
public class UploadServlet extends HttpServlet {
  
    public void doPost(HttpServletRequest request, HttpServletResponse response) {
  
        String filename = null;
        try {
            DiskFileItemFactory factory = new DiskFileItemFactory();
            ServletFileUpload upload = new ServletFileUpload(factory);
            // 設定上傳檔案的大小限制為1M
            factory.setSizeThreshold(1024 * 1024);
             
            List items = null;
            try {
                items = upload.parseRequest(request);
            } catch (FileUploadException e) {
                e.printStackTrace();
            }
  
            Iterator iter = items.iterator();
            while (iter.hasNext()) {
                FileItem item = (FileItem) iter.next();
                if (!item.isFormField()) {
  
                    // 根據時間戳建立頭像檔案
                    filename = System.currentTimeMillis() + ".jpg";
                    String photoFolder = "e:\\project\\j2ee\\web\\uploaded";
                    File f = new File(photoFolder, filename);
                    f.getParentFile().mkdirs();
  
                    // 通過item.getInputStream()獲取瀏覽器上傳的檔案的輸入流
                    InputStream is = item.getInputStream();
  
                    // 複製檔案
                    FileOutputStream fos = new FileOutputStream(f);
                    byte b[] = new byte[1024 * 1024];
                    int length = 0;
                    while (-1 != (length = is.read(b))) {
                        fos.write(b, 0, length);
                    }
                    fos.close();
  
                } else {
                    System.out.println(item.getFieldName());
                    String value = item.getString();
                    value = new String(value.getBytes("ISO-8859-1"), "UTF-8");
                    System.out.println(value);
                }
            }
             
            String html = "<img width='200' height='150' src='uploaded/%s' />";
            PrintWriter pw= response.getWriter();
            pw.format(html, filename);
             
        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

三、配置web.xml

<servlet>
    <servlet-name>UploadServlet</servlet-name>
    <servlet-class>UploadServlet</servlet-class>
</servlet>
 
<servlet-mapping>
    <servlet-name>UploadServlet</servlet-name>
    <url-pattern>/uploadPhoto</url-pattern>
</servlet-mapping>

<end>