Java组件commons fileupload实现文件上传功能

作者:白糖_ 时间:2022-05-03 15:03:07 

Apache提供的commons-fileupload jar包实现文件上传确实很简单,最近要用Servlet/JSP做一个图片上传功能,在网上找了很多资料,大多是基于struts框架介绍的,还有些虽然也介绍common-fileupload的上传,但是那些例子比较老,有些类现在都废弃了。

通过研究学习总结,终于完成了这个上传功能,下面与大家分享一下。

案例场景

一个图书馆后台管理界面,需要提供上传图书图片的功能并且最终显示在页面中。

实现效果

进入添加书籍页面,默认显示一个图片“暂无突破”(长宽均为200px),提供一个按钮“上传图片”,如下图效果。

 Java组件commons fileupload实现文件上传功能

点击“上传图片”按钮,通过模式窗口弹出上传界面,如下图所示。

Java组件commons fileupload实现文件上传功能

通过“浏览”按钮选择指定图片,点击“上传”按钮进行上传,如果上传成功则弹出成功提示,用户点击“确定”后关闭弹出窗并自动将新图片显示在页面上,如下图所示。

Java组件commons fileupload实现文件上传功能

Java组件commons fileupload实现文件上传功能

代码实现

 ①首先创建一个添加书籍页面:bookAdd.jsp

 页面id为photo_id的hidden标签用于存储图片路径,方便提交到后台存放到数据库,id为img_id的<img>标签用于显示图片,所有图片都存放在服务器下,方便读取。然后一个关键js,点击button通过模式窗口弹出上传页面,在弹出模式窗口时定义了一个变量win,该变量用于获取模式窗口传回的图片路径值。

 (注意:因为安全性问题图片不能图片不能随意存放,项目部署在服务器中,图片就只能放在该服务器下才能查看得到,如果一定要读取非当前服务器下的图片需要配置服务器的虚拟目录)


<html>
<head>
 <title>添加书籍</title>
 <script type="text/javascript">
  //打开上传页面
  function openUpload(){
   var win = window.showModalDialog("<%=root%>/Admin/bookUpload.jsp","","dialogWidth:300px;dialogHeight:300px;scroll:no;status:no");
   if(win != null){
    document.getElementById("photo_id").value = win;
    document.getElementById("img_id").src = "<%=root%>/"+win;
   }
  }
 </script>
</head>
<body>
 <h5>添加书籍</h5><hr/>
  <p>
   书的封面:
   <label>
    <input type="hidden" id="photo_id" name="photo" value="images/noimg.png"><input type="button" onclick="openUpload()" value="上传图片"/><br/>
    <img id="img_id" alt="" src="<%=root%>/images/noimg.png" width="200px" height="200px">
   </label>
  </p>
 </body>
</html>

  ②创建上传图片页面,bookUpload.jsp

 注意一定要定义<base>标签,当前模式窗口关闭时才能将数据返回到父窗体,<form>标签还要设置一个属性enctype="multipart/form-data"这样提交的文件才能被后台获取,点击“上传”button即可将文件向后台传送,剩下的重头戏就是后台上传处理了。


<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=GBK">
 <meta http-equiv="pragma" content="no-cache" />
 <span style="color: #ff0000;"><base target="_self"></span>
 <title>书籍图片上传</title>
</head>
<body>
 <h5>图片上传</h5><hr/>
 <p style="color: red">${requestScope.errorMsg}</p>
 <form id="form1" name="form1" action="<%=root%>/BookServlet?type=bookUpload" method="post" enctype="multipart/form-data">
  <div>注:图片大小最大不能超过3M!</div>
  <div><input type="file" name="file_upload"/></div>
  <div><input type="submit" value="上传"/></div>
 </form>
</body>
</html>

  ③创建一个普通的Servlet,下面只提供部分关键代码

 红色代码部分是上传的关键代码,其它就是作为点缀了。完成这三步,一个简单的上传即实现了。


public class BookServlet extends HttpServlet {

private String uploadPath = "eShop/upload/"; // 上传文件的目录
private String tempPath = "eShop/uploadtmp/"; // 临时文件目录
private String serverPath = null;

private int sizeMax = 3;//图片最大上限
private String[] fileType = new String[]{".jpg",".gif",".bmp",".png",".jpeg",".ico"};

public void doGet(HttpServletRequest request, HttpServletResponse response)
  throws ServletException, IOException {
 serverPath = getServletContext().getRealPath("/").replace("\\", "/");
 //Servlet初始化时执行,如果上传文件目录不存在则自动创建
 if(!new File(serverPath+uploadPath).isDirectory()){
  new File(serverPath+uploadPath).mkdirs();
 }
 if(!new File(serverPath+tempPath).isDirectory()){
  new File(serverPath+tempPath).mkdirs();
 }

<span style="color: #ff0000;">DiskFileItemFactory factory = new DiskFileItemFactory();</span>
 factory.setSizeThreshold(5*1024); //最大缓存
 factory.setRepository(new File(serverPath+tempPath));//临时文件目录

<span style="color: #ff0000;">ServletFileUpload upload = new ServletFileUpload(factory);</span>
 upload.setSizeMax(sizeMax*1024*1024);//文件最大上限

String filePath = null;
 try {
  <span style="color: #ff0000;">List<FileItem> items = upload.parseRequest(request);</span>//获取所有文件列表
  for (FileItem item : items) {
   //获得文件名,这个文件名包括路径
   <span style="color: #ff0000;">if(!item.isFormField()){</span>
    //文件名
    String fileName = item.getName().toLowerCase();

if(fileName.endsWith(fileType[0])||fileName.endsWith(fileType[1])||fileName.endsWith(fileType[2])||fileName.endsWith(fileType[3])||fileName.endsWith(fileType[4])||fileName.endsWith(fileType[5])){
     String uuid = UUID.randomUUID().toString();
     filePath = serverPath+uploadPath+uuid+fileName.substring(fileName.lastIndexOf("."));
     <span style="color: #ff0000;">item.write(new File(filePath));</span>
     PrintWriter pw = response.getWriter();
     pw.write("<script>alert('上传成功');window.returnValue='"+uploadPath+uuid+fileName.substring(fileName.lastIndexOf("."))+"';window.close();</script>");
     pw.flush();
     pw.close();
    }else{
     request.setAttribute("errorMsg", "上传失败,请确认上传的文件存在并且类型是图片!");
     request.getRequestDispatcher("/Admin/bookUpload.jsp").forward(request,
       response);
    }
   }
  }
 } catch (Exception e) {
  e.printStackTrace();
  request.setAttribute("errorMsg", "上传失败,请确认上传的文件大小不能超过"+sizeMax+"M");
  request.getRequestDispatcher("/Admin/bookUpload.jsp").forward(request,
    response);
 }

}
标签:java,commons,fileupload,文件上传
0
投稿

猜你喜欢

  • C#并行编程之信号量

    2023-10-08 19:26:54
  • Java简单高效实现分页功能

    2022-05-24 13:56:02
  • 详解Java中NullPointerException异常的原因详解以及解决方法

    2023-01-22 20:13:28
  • java substring 截取字符串的方法

    2023-02-12 17:21:19
  • java基础的详细了解第六天

    2021-11-05 16:18:49
  • Java实现酒店客房管理系统

    2023-11-21 06:58:38
  • java使用IO流对数组排序实例讲解

    2023-09-04 02:24:19
  • Java 控制线程的方法

    2022-10-14 15:20:22
  • java开发之闹钟的实现代码

    2021-07-08 12:46:49
  • JavaSE的逻辑控制你了解吗

    2023-01-07 01:32:22
  • Spark SQL关于性能调优选项详解

    2021-11-05 22:32:56
  • 排序算法图解之Java冒泡排序及优化

    2022-07-16 01:28:38
  • C#实现3步手动建DataGridView的方法

    2021-10-13 22:35:56
  • 使用IDEA创建servlet JavaWeb 应用及使用Tomcat本地部署的实现

    2023-09-11 06:04:09
  • 浅谈maven单元测试设置代理

    2022-03-14 20:23:04
  • Javaweb监听器实例之统计在线人数

    2023-02-08 11:47:23
  • SpringMVC @RequestBody的使用解析

    2022-01-30 06:34:32
  • c# 制作gif的四种方法

    2023-03-17 20:01:08
  • Java并发的CAS原理与ABA问题的讲解

    2023-11-25 12:17:21
  • Spring整合MyBatis图示过程解析

    2023-11-13 11:45:09
  • asp之家 软件编程 m.aspxhome.com