欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java使用common-fileupload实现文件上传

程序员文章站 2024-03-12 11:17:08
文件上传是网站非常常用的功能,直接使用servlet获取上传文件还得解析请求参数,比较麻烦,所以一般选择采用apache的开源工具,common-fileupload.这个...

文件上传是网站非常常用的功能,直接使用servlet获取上传文件还得解析请求参数,比较麻烦,所以一般选择采用apache的开源工具,common-fileupload.这个jar包可以再apache官网上面找到,也可以在struts的lib文件夹下面找到,struts上传的功能就是基于这个实现的。

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);//设置创建缓冲大小 
     
    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);//放入到数据库中 
           
        } 
      } 
    } catch (exception e) { 
       
      e.printstacktrace(); 
    } 
  } 
 
  public void dopost(httpservletrequest request, httpservletresponse response) 
      throws servletexception, ioexception { 
    doget(request, response); 
 
  } 
 
}

 这里分别判断是否是上传的流或者表单里面的参数,比如文本框提交信息,然后将他们插入到数据库中。数据库插入
代码如下

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 { 
  /** 
   * 将上传的文件流放入到数据库中 
   */ 
  public void insert(inputstream in, string filename, string type,string describe) throws exception{//向数据库中写入图片  
    connection conn = null;  
    preparedstatement ps = null;  
    resultset rs = null;  
    system.out.println(describe); 
    try {  
      // 2.建立连接  
      conn = jdbcutils.getconnection(); 
      // 3.创建语句  
      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.执行语句  
      ps.executeupdate();  
  
      in.close();  
  
      
    } finally {  
      jdbcutils.free(rs, ps, conn);  
    }  
  }  
} 

可能会遇到数据库默认问价大小限制,需要在mysql安装目录下面的my.ini下面更改如下配置,
[mysqld] 
max_allowed_packet=64m 

这样就可以了。当然,注意编码格式。上传文件搞定。还有就是我的一个列名设置为describe,结果和mysql保留字冲
突,出现无法插入信息现象,以后一定要注意。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。