java使用common-fileupload实现文件上传
文件上传是网站非常常用的功能,直接使用Servlet获取上传文件还得解析请求参数,比较麻烦,所以一般选择采用apache的开源工具,common-fileupload.这个jar包可以再apache官网上面找到,也可以在struts的lib文件夹下面找到,struts上传的功能就是基于这个实现的。
common-fileupload是依赖于common-io这个包的,所以还需要下载这个包。然后导入到你的项目路径下面。
使用代码如下
packageoop.hg.ytu.servlet;
importjava.io.File;
importjava.io.IOException;
importjava.io.InputStream;
importjava.util.List;
importjavax.servlet.ServletException;
importjavax.servlet.http.HttpServlet;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
importoop.hu.ytu.dao.UploadDomain;
importorg.apache.commons.fileupload.FileItem;
importorg.apache.commons.fileupload.disk.DiskFileItemFactory;
importorg.apache.commons.fileupload.servlet.ServletFileUpload;
publicclassUploadextendsHttpServlet{
/**
*处理用户上传请求
*/
privatestaticfinallongserialVersionUID=1L;
publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)
throwsServletException,IOException{
//Stringdescribe=request.getParameter("describe");
DiskFileItemFactoryfactory=newDiskFileItemFactory();
@SuppressWarnings("deprecation")
Stringpath=request.getRealPath("/upload");//设置磁盘缓冲路径
factory.setRepository(newFile(path));
factory.setSizeThreshold(1024*1024);//设置创建缓冲大小
ServletFileUploadupload=newServletFileUpload(factory);
upload.setSizeMax(-1);//设置上传文件限制大小,-1无上限
try{
@SuppressWarnings("unchecked")
List<FileItem>list=upload.parseRequest(request);
Stringva=null;
for(FileItemitem:list){
//Stringname=item.getFieldName();
if(item.isFormField()){//判断是否是文件流
va=item.getString("UTF-8");
//System.out.println(name+"="+va);
///request.setAttribute(name,value);
}else{
Stringvalue=item.getName();//会将完整路径名传过来
intstart=value.lastIndexOf("\\");
StringfileName=value.substring(start+1);
//request.setAttribute(name,fileName);
InputStreamin=item.getInputStream();
UploadDomaindao=newUploadDomain();
//item.write(newFile(realPath,fileName));
intindex=fileName.lastIndexOf(".");
StringrealFileName=fileName.substring(0,index);
Stringtype=fileName.substring(index+1);
dao.insert(in,realFileName,type,va);//放入到数据库中
}
}
}catch(Exceptione){
e.printStackTrace();
}
}
publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)
throwsServletException,IOException{
doGet(request,response);
}
}
这里分别判断是否是上传的流或者表单里面的参数,比如文本框提交信息,然后将他们插入到数据库中。数据库插入
代码如下
packageoop.hu.ytu.dao;
importjava.io.InputStream;
importjava.sql.Connection;
importjava.sql.PreparedStatement;
importjava.sql.ResultSet;
importoop.hg.ytu.utils.JdbcUtils;
/**
*提供文件上传支持
*@authorAdministrator
*
*/
publicclassUploadDomain{
/**
*将上传的文件流放入到数据库中
*/
publicvoidinsert(InputStreamin,StringfileName,Stringtype,Stringdescribe)throwsException{//向数据库中写入图片
Connectionconn=null;
PreparedStatementps=null;
ResultSetrs=null;
System.out.println(describe);
try{
//2.建立连接
conn=JdbcUtils.getConnection();
//3.创建语句
Stringsql="insertintofileupload(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.执行语句
ps.executeUpdate();
in.close();
}finally{
JdbcUtils.free(rs,ps,conn);
}
}
}
可能会遇到数据库默认问价大小限制,需要在mysql安装目录下面的my.ini下面更改如下配置,
[mysqld]
max_allowed_packet=64M
这样就可以了。当然,注意编码格式。上传文件搞定。还有就是我的一个列名设置为describe,结果和Mysql保留字冲
突,出现无法插入信息现象,以后一定要注意。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。