文件上传与下载(基于前端页面到Servlet服务器),文末领取面试资料

avatar
作者
筋斗云
阅读量:1

| — | — |

| ServletFileUpload 类 | 用于解析上传的数据 |

| FileItem 类 | 表示每一个表单项 |

| boolean ServletFileUpload.isMultipartContent(HttpServletRequest request) | 判断当前上传的数据格式是否是多段的格式 |

| public List parseRequest(HttpServletRequest request) | 解析上传的数据 |

| boolean FileItem.isFormField() | 判断当前这个表单项,是普通的表单项,还是上传的文件类型 |

| String FileItem.getFieldName() | 获取表单项的name 属性值 |

| String FileItem.getString() | 获取当前表单项的值 |

| String FileItem.getName() | 获取上传的文件名 |

| void FileItem.write( file ) | 将上传的文件写到参数 file 所指向的硬盘位置 |

4)在src目录下新建UploadServlet.java文件,以此来处理我们对于前端页面上传的内容。对应的处理包括在IDEA控制台显示表单上传的name属性值以及将前端页面上传的图片保存到本地电脑中

import org.apache.commons.fileupload.FileItem;

import org.apache.commons.fileupload.FileItemFactory;

import org.apache.commons.fileupload.disk.DiskFileItemFactory;

import org.apache.commons.fileupload.servlet.ServletFileUpload;

import javax.servlet.ServletException;

import javax.servlet.ServletInputStream;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.File;

import java.io.IOException;

import java.util.List;

/**

  • 编写服务器代码(用Servlet接收),处理网页(JSP)上传的数据。

*/

public class UploadServlet extends HttpServlet {

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

// //一:直接将前端JSP页面上form表单的内容打印出来

// //1 为什么接收不到呢?因为客户端是以流的形式发送的,所以必须以流的形式接收

// System.out.println(req.getParameter(“username”));

// System.out.println(req.getParameter(“photo”));

//

// //2 就像Socket通讯一样接收。但这里我直接用一个巨大的buf将数据一次性全放在缓冲区

// // 可以看到打印出来的字符串是按照Http协议的,Http协议如下

// ServletInputStream inputStream = req.getInputStream();

// byte[] buf = new byte[102400];

// int length = inputStream.read(buf);

// System.out.println(new String(buf, 0, length));

//二:接下来使用第三方jar包来处理,可以看到服务端已经收到客户端的数据,现在的问题就是怎么将我们的数据解析

// 成我们想要的文件,其实像这种文件上传的非常常见的功能,已经有很多第三方jar包为我们做了模块的封装。

//1 先判断上传的数据是否多段数据(只有是多段的数据,才是文件上传的)

if (ServletFileUpload.isMultipartContent(req)) {

//创建FileItemFactory工厂实现类,对于一个接口,我们肯定要找它的实现类来发现其功能

FileItemFactory fileItemFactory = new DiskFileItemFactory();

// 创建用于解析上传数据的工具类ServletFileUpload类

ServletFileUpload servletFileUpload = new ServletFileUpload(fileItemFactory);

try {

// 解析上传的数据,得到每一个表单项FileItem

List list = servletFileUpload.parseRequest(req);

// 循环判断,每一个表单项,是普通类型,还是上传的文件

for (FileItem fileItem : list) {

if (fileItem.isFormField()) {

// 普通表单项

System.out.println(“普通表单项的name属性值:” + fileItem.getFieldName());

// 参数UTF-8.解决乱码问题

System.out.println(“普通表单项的value属性值:” + fileItem.getString(“UTF-8”));

} else {

// 上传的文件

System.out.println(“文件表单项的name属性值:” + fileItem.getFieldName());

System.out.println(“上传的文件名:” + fileItem.getName());

fileItem.write(new File(“E:\” + fileItem.getName()));

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

}

5)在web.xml中加入配置文件以此来实现前端和后端的映射

UploadServlet

sharm.servlet.UploadServlet

UploadServlet

/uploadServlet

这样就大功告成了!

4 文件的下载

==========================================================================

实例: 服务器将文件返回给客户端,同时让客户端可以下载该图片。

操作步骤:

1)在src目录下新建DownloadServlet.java文件

import org.apache.commons.io.IOUtils;

import javax.servlet.ServletContext;

import javax.servlet.ServletException;

import javax.servlet.ServletOutputStream;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.IOException;

import java.io.InputStream;

import java.net.URLEncoder;

public class DownloadServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//1 获取要下载的文件名

String downloadFileName = “1.jpg”;

//2 读取要下载的文件内容(通过Servlet对象可以读取)

ServletContext servletContext = getServletContext();

//2.1 获取要下载文件的文件类型

String mimeType = servletContext.getMimeType(“/picture/” + downloadFileName);

System.out.println(“下载的文件类型为:” + mimeType);

//2.2 在回传前通过响应头告诉客户端返回的数据类型

resp.setContentType(mimeType);

//2.3 到这里为止,我们只能返回给客户端,但图片却直接在浏览器中显示

// 还要告诉客户端收到的数据是用来下载的(还是用过响应头的方式)

resp.setHeader(“Content-Disposition”, “attachment; fileName” + downloadFileName);

//2.4 其中的/在服务器端解析的是http://ip:port/工程名/ 也就是映射到当前工程的web目录

InputStream resourceAsStream = servletContext.getResourceAsStream(“/picture/” + downloadFileName);

//2.5 获取响应的输出流:本来需要先将流转换成某一个数组,再将数组转化成流,现在我们可以直接用jar包的方法进行两种流的直接转换

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

总结

技术学到手后,就要开始准备面试了,找工作的时候一定要好好准备简历,毕竟简历是找工作的敲门砖,还有就是要多做面试题,复习巩固。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

真正体系化!**

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-PPvOlY6n-1711865173221)]

总结

技术学到手后,就要开始准备面试了,找工作的时候一定要好好准备简历,毕竟简历是找工作的敲门砖,还有就是要多做面试题,复习巩固。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!