在Action中使用FileUpload,把页面的信息从request放到list中,为什么list为0啊?请高手指点!!!!

 

  在Action中使用FileUpload,把页面的信息从request放到list中,为什么list为0啊?请高手指点!!!!代码如下:

 

 

public ActionForward execute(ActionMapping mapping, ActionForm form,
   HttpServletRequest request, HttpServletResponse response) {
  
  DiskFileItemFactory dfif = new DiskFileItemFactory();
  dfif.setSizeThreshold(4096);// 设置上传文件时用于临时存放文件的内存大小,这里是4K.多于的部分将临时存在硬盘
  dfif
    .setRepository(new File(request.getRealPath("/")
      + "ImagesUploaded"));// 设置存放临时文件的目录,web根目录下的ImagesUploadTemp目录

  // 用以上工厂实例化上传组件
  ServletFileUpload sfu = new ServletFileUpload(dfif);
  // 设置最大上传尺寸
  sfu.setSizeMax(4100000);

  // 从request得到 所有 上传域的列表
   try {
    List fileList = null;
      fileList = sfu.parseRequest(request);
      System.out.println("fileList为:"+fileList);
      
    System.out.println(fileList.size() + "aswwwdf");
   } catch (FileUploadException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }

  

  return mapping.findForward("");
 }

首先,需要在JSP页面使用form表单来上传文件,并且添加enctype属性来指定form表单的编码类型为multipart/form-data,示例如下: ``` <form action="upload.jsp" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上传"> </form> ``` 然后,在后台的upload.jsp页面,需要使用Commons FileUpload组件来处理上传的文件,并将文件存储到数据库。可以按照以下步骤进行操作: 1. 创建DiskFileItemFactory对象,并设置缓冲区大小和临时文件存储路径: ``` DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(4096); factory.setRepository(new File("D:/temp")); ``` 2. 创建ServletFileUpload对象,并设置文件上传的最大值和编码格式: ``` ServletFileUpload upload = new ServletFileUpload(factory); upload.setSizeMax(1024*1024*10); //设置文件上传的最大值为10M upload.setHeaderEncoding("UTF-8"); //设置编码格式为UTF-8 ``` 3. 解析求,获取上传的文件: ``` List<FileItem> items = upload.parseRequest(request); for (FileItem item : items) { if (!item.isFormField()) { //判断是否为文件域 String filename = item.getName(); //获取文件名 InputStream in = item.getInputStream(); //获取文件输入流 //将文件存储到数据库 //... } } ``` 4. 将文件存储到数据库: ``` //获取数据库连接 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root"); PreparedStatement pstmt = null; //插入数据的SQL语句 String sql = "INSERT INTO image (name, content) VALUES (?, ?)"; try { pstmt = conn.prepareStatement(sql); pstmt.setString(1, filename); pstmt.setBinaryStream(2, in, in.available()); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭数据库连接和输入流 if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (in != null) { try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 以上就是使用Commons FileUpload组件将图片上传到数据库的基本步骤。需要注意的是,在实际应用,还需要进行文件类型、大小、重名等的校验,以及异常处理等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值