java使用common-fileupload實現(xiàn)文件上傳
文件上傳是網(wǎng)站非常常用的功能,直接使用Servlet獲取上傳文件還得解析請求參數(shù),比較麻煩,所以一般選擇采用apache的開源工具,common-fileupload.這個jar包可以再apache官網(wǎng)上面找到,也可以在struts的lib文件夾下面找到,struts上傳的功能就是基于這個實現(xiàn)的。
common-fileupload是依賴于common-io這個包的,所以還需要下載這個包。然后導入到你的項目路徑下面。
使用代碼如下
package oop.hg.ytu.servlet;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import oop.hu.ytu.dao.UploadDomain;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
public class Upload extends HttpServlet {
/**
* 處理用戶上傳請求
*/
private static final long serialVersionUID = 1L;
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// String describe = request.getParameter("describe");
DiskFileItemFactory factory = new DiskFileItemFactory();
@SuppressWarnings("deprecation")
String path = request.getRealPath("/upload");//設置磁盤緩沖路徑
factory.setRepository(new File(path));
factory.setSizeThreshold(1024*1024);//設置創(chuàng)建緩沖大小
ServletFileUpload upload = new ServletFileUpload(factory);
upload.setSizeMax(-1);//設置上傳文件限制大小,-1無上限
try {
@SuppressWarnings("unchecked")
List<FileItem> list = upload.parseRequest(request);
String va = null;
for(FileItem item : list){
// String name = item.getFieldName();
if(item.isFormField()){//判斷是否是文件流
va = item.getString("UTF-8");
// System.out.println(name+"="+va);
/// request.setAttribute(name, value);
}else{
String value = item.getName();//會將完整路徑名傳過來
int start = value.lastIndexOf("\\");
String fileName = value.substring(start+1);
// request.setAttribute(name, fileName);
InputStream in = item.getInputStream();
UploadDomain dao = new UploadDomain();
//item.write(new File(realPath,fileName));
int index = fileName.lastIndexOf(".");
String realFileName = fileName.substring(0,index);
String type = fileName.substring(index+1);
dao.insert(in, realFileName,type,va);//放入到數(shù)據(jù)庫中
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
這里分別判斷是否是上傳的流或者表單里面的參數(shù),比如文本框提交信息,然后將他們插入到數(shù)據(jù)庫中。數(shù)據(jù)庫插入
代碼如下
package oop.hu.ytu.dao;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import oop.hg.ytu.utils.JdbcUtils;
/**
* 提供文件上傳支持
* @author Administrator
*
*/
public class UploadDomain {
/**
* 將上傳的文件流放入到數(shù)據(jù)庫中
*/
public void insert(InputStream in, String fileName, String type,String describe) throws Exception{//向數(shù)據(jù)庫中寫入圖片
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
System.out.println(describe);
try {
// 2.建立連接
conn = JdbcUtils.getConnection();
// 3.創(chuàng)建語句
String sql = "insert into fileupload(file,filename,type,des) values (?,?,?,?)";
ps = conn.prepareStatement(sql);
ps.setBlob(1, in);
ps.setString(2, fileName);
ps.setString(3, type);
ps.setString(4, describe);
// 4.執(zhí)行語句
ps.executeUpdate();
in.close();
} finally {
JdbcUtils.free(rs, ps, conn);
}
}
}
可能會遇到數(shù)據(jù)庫默認問價大小限制,需要在mysql安裝目錄下面的my.ini下面更改如下配置,
[mysqld]
max_allowed_packet=64M
這樣就可以了。當然,注意編碼格式。上傳文件搞定。還有就是我的一個列名設置為describe,結(jié)果和Mysql保留字沖
突,出現(xiàn)無法插入信息現(xiàn)象,以后一定要注意。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- java組件SmartUpload和FileUpload實現(xiàn)文件上傳功能
- Java中使用fileupload組件實現(xiàn)文件上傳功能的實例代碼
- java組件commons-fileupload實現(xiàn)文件上傳、下載、在線打開
- Java組件commons fileupload實現(xiàn)文件上傳功能
- JavaEE組件commons-fileupload實現(xiàn)文件上傳、下載
- java組件commons-fileupload文件上傳示例
- java組件fileupload文件上傳demo
- java組件commons-fileupload實現(xiàn)文件上傳
- JAVA使用commos-fileupload實現(xiàn)文件上傳與下載實例解析
- 使用fileupload組件實現(xiàn)文件上傳功能
相關文章
詳解mysql插入數(shù)據(jù)后返回自增ID的七種方法
這篇文章主要介紹了詳解mysql插入數(shù)據(jù)后返回自增ID的七種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12
JDBC插入數(shù)據(jù)返回數(shù)據(jù)主鍵代碼實例
這篇文章主要介紹了JDBC插入數(shù)據(jù)返回數(shù)據(jù)主鍵代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11
Spring Boot結(jié)合IDEA自帶Maven插件如何快速切換profile
IDEA是目前 Java 開發(fā)者中使用最多的開發(fā)工具,它有著簡約的設計風格,強大的集成工具,便利的快捷鍵,這篇文章主要介紹了Spring Boot結(jié)合IDEA自帶Maven插件快速切換profile,需要的朋友可以參考下2023-03-03

