Servlet實現(xiàn)簡單文件上傳功能
本文實例為大家分享了Servlet文件上傳的具體代碼,供大家參考,具體內(nèi)容如下
兩點要素:
1.表單提交方式必須是post
2.enctype一定要是multipart/form-data。
enctype的默認值是application/x-www-form-urlencoded,
這種編碼格式只支持鍵值對的數(shù)據(jù),?鍵=值&鍵=值,只能是字符串,無法傳輸文件。
multipart/form-data這種編碼可以上傳文件
需要的jar包:
實現(xiàn):
import java.io.BufferedInputStream; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.PrintWriter; 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 { //文件夾路徑常量 private static String TEMP_PATH = "E:/Learning/temp/170926"; private static final long serialVersionUID = 3364746345428715093L; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request, response); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); // 接收文件 boolean isMultipart = ServletFileUpload.isMultipartContent(request); // 判斷是否是文件上傳請求 if (!isMultipart) { out.println("Error : 表單必須包含 enctype=multipart/form-data"); return; } // 用于創(chuàng)建解析文件上傳的工廠類 DiskFileItemFactory factory = new DiskFileItemFactory(); // 用于從請求中解析出文件 ServletFileUpload upload = new ServletFileUpload(factory); try { // 獲取所有提交過來的文件(包含表單內(nèi)容) 這個FileItem叫做一個項,這個項有可能是文件也有可能是表單參數(shù) List<FileItem> items = upload.parseRequest(request); // 定義一個輸出流 FileOutputStream fos = null; //緩沖區(qū) byte [] buf = new byte[8192]; if (items != null && items.size() > 0) { // 不為空且長度大于0則遍歷之 for (FileItem item : items) { if (item.isFormField()) { // isFormField = true 文本框的值 out.println("用戶名: " + item.getString() + "<br />"); } else { //獲取輸入流 BufferedInputStream bis = new BufferedInputStream(item.getInputStream()); //初始化本地輸出流 fos = new FileOutputStream(new File(TEMP_PATH + "/" + item.getName())); int len = -1; while ((len = bis.read(buf)) != -1) { fos.write(buf , 0 , len); fos.flush(); } out.println("文件: " + item.getName() + "已上傳 <br />"); } } } } catch (FileUploadException e) { out.println("Error: 文件解析異常"); } } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
簡單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系
這篇文章主要介紹了簡單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03Java?-jar參數(shù)設(shè)置小結(jié)
本文主要介紹了Java?-jar參數(shù)設(shè)置小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06Java排序算法三之歸并排序的遞歸與非遞歸的實現(xiàn)示例解析
這篇文章主要介紹了Java排序算法三之歸并排序的遞歸與非遞歸的實現(xiàn)示例解析,文章通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08SpringSecurity框架下實現(xiàn)CSRF跨站攻擊防御的方法
CSRF是一種網(wǎng)絡(luò)攻擊方式,也可以說是一種安全漏洞,這種安全漏洞在web開發(fā)中廣泛存在。這篇文章主要介紹了SpringSecurity框架下實現(xiàn)CSRF跨站攻擊防御,需要的朋友可以參考下2019-12-12用StopWatch優(yōu)雅替代currentTimeMillis計算程序執(zhí)行耗時
別再用System.currentTimeMillis()計算程序執(zhí)行耗時了,擁抱StopWatch優(yōu)雅來優(yōu)雅的計算,代碼更簡潔效率更高,本文帶你了解StopWatch的使用2021-09-09基于Java的打包jar、war、ear包的作用與區(qū)別詳解
本篇文章,小編為大家介紹,基于Java的打包jar、war、ear包的作用與區(qū)別詳解。需要的朋友參考下2013-04-04