JavaWeb案例(一):使用response对象下载文件
JavaWeb案例(一):使用response对象下载文件
web服务器接收到客户端的http请求,就会针对这个请求,分别创建一个代表请求的HttpServletRequest对象,代表响应的HttpServletResponse对象。
如果获取客户端请求过来的参数:找HttpServletRequest
如果要给客户端响应一些信息:找HttpServletResponse
1.首先我们通过查看该接口的源码,我们先将其中的方法简单分类:
负责想浏览器发送数据的方法:
ServletOutputStream getOutputStream() throws IOException;
PrintWriter getWriter() throws IOException;
负责向浏览器发送响应头的方法:
void setCharacterEncoding(String var1);
void setContentLength(int var1);
void setContentLengthLong(long var1);
void setContentType(String var1);
void setDateHeader(String var1, long var2);
void addDateHeader(String var1, long var2);
void setHeader(String var1, String var2);
void addHeader(String var1, String var2);
void setIntHeader(String var1, int var2);
void addIntHeader(String var1, int var2);
响应的状态码:
int SC_CONTINUE = 100;
int SC_SWITCHING_PROTOCOLS = 101;
int SC_OK = 200;
int SC_CREATED = 201;
int SC_ACCEPTED = 202;
int SC_NON_AUTHORITATIVE_INFORMATION = 203;
int SC_NO_CONTENT = 204;
int SC_RESET_CONTENT = 205;
int SC_PARTIAL_CONTENT = 206;
int SC_MULTIPLE_CHOICES = 300;
int SC_MOVED_PERMANENTLY = 301;
int SC_MOVED_TEMPORARILY = 302;
int SC_FOUND = 302;
int SC_SEE_OTHER = 303;
int SC_NOT_MODIFIED = 304;
int SC_USE_PROXY = 305;
int SC_TEMPORARY_REDIRECT = 307;
int SC_BAD_REQUEST = 400;
int SC_UNAUTHORIZED = 401;
int SC_PAYMENT_REQUIRED = 402;
int SC_FORBIDDEN = 403;
int SC_NOT_FOUND = 404;
int SC_METHOD_NOT_ALLOWED = 405;
int SC_NOT_ACCEPTABLE = 406;
int SC_PROXY_AUTHENTICATION_REQUIRED = 407;
int SC_REQUEST_TIMEOUT = 408;
int SC_CONFLICT = 409;
int SC_GONE = 410;
int SC_LENGTH_REQUIRED = 411;
int SC_PRECONDITION_FAILED = 412;
int SC_REQUEST_ENTITY_TOO_LARGE = 413;
int SC_REQUEST_URI_TOO_LONG = 414;
int SC_UNSUPPORTED_MEDIA_TYPE = 415;
int SC_REQUESTED_RANGE_NOT_SATISFIABLE = 416;
int SC_EXPECTATION_FAILED = 417;
int SC_INTERNAL_SERVER_ERROR = 500;
int SC_NOT_IMPLEMENTED = 501;
int SC_BAD_GATEWAY = 502;
int SC_SERVICE_UNAVAILABLE = 503;
int SC_GATEWAY_TIMEOUT = 504;
int SC_HTTP_VERSION_NOT_SUPPORTED = 505;
2.常见应用:
向浏览器输出消息(通过响应对象调用方法得到流对象,向浏览器输出内容,不做过多解释很简单)
下载文件(重点)
步骤如下:
1.要获取下载文件的路径
2.下载的文件名字是什么
3.设置想办法让浏览器能够支持下载我们需要的东西
4.获取下载文件的输入流
5.创建缓冲区
6.获取OutputStream对象
7.将FileOutputStream流写入到缓冲区,使用OutputStream将缓冲区中的数据输出到客户端
注意:我们这次下载的对象是一张图片,图片名字为:1.png
这段代码的关键就是:resp.setHeader("Content-Disposition","attachment;filename=" + fileName);
代码展示如下:
package com.xu.servlet;
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.FileInputStream;
import java.io.IOException;
public class FileServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//1.要获取下载文件的路径
String realPath = "D:\\IdeaProjects\\untitled11\\untitled\\untitled11\\javaweb-servlet\\response\\target\\classes\\1.png";
System.out.println("下载文件的路径为:" + realPath);
//2.下载的文件名字是什么
String fileName = realPath.substring(realPath.lastIndexOf("//") + 1);
//3.设置想办法让浏览器能够支持(Content-Disposition)下载我们需要的东西
resp.setHeader("Content-Disposition","attachment;filename=" + fileName);
//4.获取下载文件的输入流
FileInputStream in = new FileInputStream(realPath);
//5.创建缓冲区
int len = 0;
byte[] buffer = new byte[1024];
//6.获取OutputStream对象
ServletOutputStream out = resp.getOutputStream();
//7.将FileOutputStream流写入到缓冲区,使用OutputStream将缓冲区中的数据输出到客户端
while ((len = in.read(buffer)) > 0){
out.write(buffer,0,len);
}
in.close();
out.close();
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}
}
我们在web.xml中配置url-pattern访问路径后访问该资源会得到下载页面:
JavaWeb案例(一):使用response对象下载文件相关教程
vue项目中使用轮播组件vue-awesome-swiper安装最新版本爬坑记
vue项目中使用轮播组件vue-awesome-swiper安装最新版本爬坑记 vue中使用swiper做轮播图=== 由版本引起的雪案 https://www.swiper.com.cn/ https://github.surmon.me/vue-awesome-swiper/ npm ivue-awesome-swiper npm将安装最新的vue-awesome-swiper(@4),
vue使用全局混入的方式实现数据字典的快速获取
vue使用全局混入的方式实现数据字典的快速获取 在开发管理系统类的项目数据字典是一个非常常用的功能,比如产品类型,业务组织,邮递类型这种比较简单的数据,有可能更改,但是大多数情况下又不会更改,用一个数据字典来维护这些数据就非常方便。下面介绍一种
Jetpack架构组件 (二)-- Lifecycle原理与使用
Jetpack架构组件 (二)-- Lifecycle原理与使用 前言 本篇文章我们将来学习 Android Jetpack 架构组件中的 Lifecycle 组件。Lifecycle 组件是帮忙我们管理 Activity 和Fragment 的生命周期,也就是说,当 Activity 或者 Fragment 的生命周期发生变化的时候我
postman上传附件 测试案例
postman上传附件 测试案例 方法名称如下: @RequestMapping(value = /batchUpload) @ResponseBody public ExecuteResultString batchAddFiles(MultipartHttpServletRequest request, Long edocId) { ExecuteResultString result = new ExecuteResult(); try{
Spring Cloud Alibaba 06_使用 Seata 实现分布式事务
Spring Cloud Alibaba 06_使用 Seata 实现分布式事务 Spring Cloud Alibaba 06_使用 Seata实现分布式事务 创建 order 模块,选择: spring web 、 JDBC API 和 MySQL Driver 创建 pay 模块,选择: spring web 、 JDBC API 和 MySQL Driver 修改 order 和 pay
vue 插槽的使用
vue 插槽的使用 1. 组件插槽的作用 父组件向 子组件 传递内容: 不是之前的数据传递,是模板数据的传递 我们平常定义的 组件模板,渲染到页面上是这样的: 比如: 我们的组件模板为 a.vue 要渲染在 b.vue 上,就是这样的: a.vue template 我是子组件,要渲染
javaweb---一个简单的web应用p59
javaweb---一个简单的web应用p59 %@ page language=java contentType=text/html; charset=UTF-8 pageEncoding=UTF-8%!DOCTYPE htmlhtmlheadmeta charset=UTF-8titleInsert title here/title/headbodykkkkkkkkk/body/html
java storm streamId 使用的例子
java storm streamId 使用的例子 Java storm 中有时候会遇到一个数据需要向后发几次,而且互不影响的。比如场景:从kafka spout里面消费数据,现在有几个 topology都是从kafka里面的同一个topic消费数据,进行后续处理的。这几个bolt都需要处理全量的数据,那