jsp 上传图片 mysql_servlet+JSP+mysql实现文件上传的方法

本文介绍了一种使用servlet、JSP和mysql实现文件上传的方法。主要内容包括设置表单属性enctype为multipart/form-data,以便支持二进制数据上传,并通过DiskFileItemFactory和ServletFileUpload等类进行文件解析与处理。
摘要由CSDN通过智能技术生成

本文实例讲述了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端

表单的ENCTYPE属性值为multipart/form-data,它告诉我们传输的数据要用到多媒体传输协议,由于多媒体传输的都是大量的数据,所以规定上传文件必须是post方法,的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 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程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值