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;
//    }

}

上传文件要注意的有:1  注意编码问题  防止出现中文乱码   上边列举出一种  其他的还有

还有临时文件解决问题    临时文件删除问题

解决没有指定文件名的问题

判断获取的文件名是否为空

保存路径问题

如表示url资源时应该用斜杠 “/”

如表示硬盘路径时用斜杠“\\”

为保证服务器安全,上传的文件应禁止用户直接访问,通常保存在应用程序的WEB-INF目录下,或者不受WEB服务器管理的目录

 




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值