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

servlet+JSP+mysql实现文件上传的方法

程序员文章站 2022-05-28 17:46:35
本文实例讲述了servlet+jsp+mysql实现文件上传的方法。分享给大家供大家参考,具体如下: 一、文件上传的基本操作: 1、 表单属性enctype的设置 m...

本文实例讲述了servlet+jsp+mysql实现文件上传的方法。分享给大家供大家参考,具体如下:

一、文件上传的基本操作:

1、 表单属性enctype的设置

multipart/form-data和application/x-www-form-urlencoded的区别

form元素的enctype属性指定了表单数据向服务器提交时所采用的编码类型,默认的缺省值是“application/x-www-form-urlencoded”。

然而,在向服务器发送大量的文本、包含非ascii字符的文本或二进制数据时这种编码方式效率很低。

在文件上载时,所使用的编码类型应当是“multipart/form-data”,它既可以发送文本数据,也支持二进制数据上载。

browser端<form>表单的enctype属性值为multipart/form-data,它告诉我们传输的数据要用到多媒体传输协议,由于多媒体传输的都是大量的数据,所以规定上传文件必须是post方法,<input>的type属性必须是file。

实现过程:

package cn.csdn.web.servlet;
import java.io.file;
import java.io.fileoutputstream;
import java.io.ioexception;
import java.io.inputstream;
import java.sql.sqlexception;
import java.util.list;
import java.util.uuid;
import javax.servlet.servletexception;
import javax.servlet.http.httpservlet;
import javax.servlet.http.httpservletrequest;
import javax.servlet.http.httpservletresponse;
import javax.sql.datasource;
import org.apache.commons.dbutils.queryrunner;
import org.apache.commons.fileupload.fileitem;
import org.apache.commons.fileupload.fileuploadbase.filesizelimitexceededexception;
import org.apache.commons.fileupload.fileuploadexception;
import org.apache.commons.fileupload.disk.diskfileitemfactory;
import org.apache.commons.fileupload.servlet.servletfileupload;
import cn.csdn.web.c3p0.dbmanager_c3p0;
public class upload2servlet extends httpservlet {
/**
* 
*/
private static final long serialversionuid = 1l;
public void doget(httpservletrequest request, httpservletresponse response)
throws servletexception, ioexception {
dopost(request,response);
}
public void dopost(httpservletrequest request, httpservletresponse response)
throws servletexception, ioexception {
request.setcharacterencoding("utf-8");
try {
//实例化一个文件工厂 
diskfileitemfactory factory=new diskfileitemfactory();
factory.setrepository(new file("c:\\osp"));
string paramname=null;
string paramvalue=null;
//配置上传组件servletfileupload 
servletfileupload upload=new servletfileupload(factory);
upload.setheaderencoding("utf-8");
upload.setfilesizemax(1024*1024);
//从request得到所有上传域的列表 
list<fileitem> list=upload.parserequest(request);
for(fileitem item:list){
//如果是上传域的文件域 
if(item.isformfield()){
//表单普通输入项
paramname = item.getfieldname(); //上传于的name
// string paramvalue=item.getstring();
// paramvalue=new string(paramvalue.getbytes("iso8859-1"),"utf-8");
paramvalue=item.getstring("utf-8");
system.out.println(paramname+"="+paramvalue);
}else{
//上传文件处理
string filename = item.getname();
filename=filename.substring(filename.lastindexof("\\")+1); //截取扩展名 
system.out.println("name="+filename);
if(!filename.equals("")){
// filename=refactorfilename(filename);
inputstream in=item.getinputstream();
file file = new file("c:\\"+filename);
fileoutputstream os=new fileoutputstream(file);
byte[] buf = new byte[1024];
int len=0;
while((len=in.read(buf))>0){
os.write(buf,0,len);
}
os.flush();
os.close();
in.close();
item.delete();
request.setattribute("message", "文件上传成功");
try {
datasource ds = dbmanager_c3p0.getdatasource();
queryrunner runner = new queryrunner(ds);
string sql = "insert into user(name,file) values(?,?)";
object[] params = {paramvalue,filename};
runner.update(sql, params);
} catch (sqlexception e) {
// todo auto-generated catch block
e.printstacktrace();
}
}
}
}
} catch(filesizelimitexceededexception e1){
e1.printstacktrace();
request.setattribute("message", "文件尺寸太大");
}catch (fileuploadexception e) {
// todo auto-generated catch block
e.printstacktrace();
request.setattribute("message", "文件上传失败");
}
request.getrequestdispatcher("/message.jsp").forward(request, response);
}
// public string refactorfilename(string filename){
// return uuid.randomuuid().tostring()+"_"+filename;
// }
}

二、上传文件要注意的有:

注意编码问题 防止出现中文乱码 上边列举出一种
其他的还有临时文件解决问题 临时文件删除问题
解决没有指定文件名的问题
判断获取的文件名是否为空
保存路径问题
如表示url资源时应该用斜杠 “/”
如表示硬盘路径时用斜杠“\\”
为保证服务器安全,上传的文件应禁止用户直接访问,通常保存在应用程序的web-inf目录下,或者不受web服务器管理的目录

希望本文所述对大家jsp程序设计有所帮助。