文件上传的例子有很多,这个博客来带你进入每个功能,每个方法的详解!
我们学过的上传的方式有两种:
- 传统:common-fileuplad上传文件
- Servlet3.0:新增的上传方式,比传统的要容易得多
语法介绍
文件上传大多用在用户添加数据的时候使用,其实是把表单中的每一项都设计成一个part对象,无论是普通项还是文件项,都是一个part(部分)对象
HttpServletRequest接口 | 说明 |
---|---|
Part getPart(String name) | 获取表单中一项,这个Part可能是普通项,也可能是文件项 参数:表单项的name属性 |
文件项Part接口 | 说明 |
---|---|
String getSubmittedFileName() | 获取上传的文件名 |
void write(String fileName) | 把文件写到服务器指定的路径 |
void delete() | 清除上传过程中生成的临时文件 |
案例:Servlet3.0实现文件上传
文件上传三要素
- form表单必须使用POST提交
- 必须指定enctype=“multipart/form-data”
- 指定文件项,并且指定名字 input type=“file” name=“名字”
步骤
1:创建web项目
2:客户端处理:
1:表单的提交方式必须是post
2:必须设置增加表单属性:enctype="multipart/form-data"
3:必须有一个文件上传组件\<input type="file" name="photo"/>,如果是上传图片,
可以指定accept属性为:image/jpeg
3:服务端处理:
1:在Servlet上添加注解@MultipartConfig
2:post汉字乱码问题
3:得到普通文本框输入的值
4:得到文件的Part对象
5:写入文件在web/img目录下,使用服务器的真实地址
6:删除临时文件
注意:
- web/img目录下必须要有内容,否则idea检查不到目录
- 开发目录下的img没有这个文件的,在out目录下去找,这才是部署的地址
代码
页面代码
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>文件上传</title>
</head>
<body>
<h2>文件上传</h2>
<%--
1. form表单必须使用POST提交
2. 必须指定enctype="multipart/form-data"
3. 指定文件项,并且指定名字 input type="file" name="名字"
--%>
<form action="upload" method="post" enctype="multipart/form-data">
名字:<input type="text" name="username"> <br/>
照片:<input type="file" name="photo">
<hr/>
<input type="submit" value="上传">
</form>
</body>
</html>
Servlet
/**
* 如果要使用servlet3.0的方式上传
* 1. 建议使用tomcat8上以的版本
* 2. 必须在Servlet指定注解 @MultipartConfig,告诉这个Servlet,这是一个enctype="multipart/form-data"这种类型的表单
*/
@MultipartConfig
@WebServlet("/demo01")
public class Demo01extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.post汉字乱码
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
//2.获取普通表单项
out.print("用户名:" + request.getParameter("username") + "<hr/>");
//3.获取文件项
Part part = request.getPart("photo");
//获取文件名
String fileName = part.getSubmittedFileName();
out.print("文件名:" + fileName + "<hr/>");
//写到服务器指定的目录下(这里有个坑:如果web目录下img是空的目录,idea不会给你创建,导致路径错误)
//获取img在服务器上真实路径
String realPath = getServletContext().getRealPath("/img");
//这一句话就实现了文件上传
part.write(realPath + "/" + fileName);
//删除临时文件
part.delete();
out.print("上传文件成功:<hr/>");
out.print("<img src='img/" + fileName + "'/>");
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}