Response

本文详细介绍了Servlet API中的HttpServletResponse接口,包括响应状态码、响应头及响应体的设置方法,并通过具体案例展示了文件下载和验证码生成的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HttpServletResponse

在Servlet API中,定义了一个HttpServletResponse接口,它继承自ServletResponse接口,专门用来封装HTTP响应消息。由于HTTP响应消息分为状态行、响应头、响应体三部分,因此,在HttpServletResponse接口中定义了向客户端发送响应状态码、响应头、响应体的方法。

响应行: 协议版本  状态码 状态描述

常用的状态码:

  • ​        200:成功
  • ​        302:重定向,需要和一个响应头
  • ​        304:访问缓存
  • ​        404:客户端错误
  • ​        500:服务器错误

响应头:  key:value;  这个value可以有多个

一个key对应一个value

230137_5SQk_3669094.png

一个key对应多个value

230126_yIae_3669094.png

    常用的响应头

  • Refresh:定时跳转
  • Location:重定向(地址)
  • Content-Disposition:设置文件下载时候的头
  • Content-Type:设置响应内容的MIME类型

响应体

230027_2tVs_3669094.png

API简介之设置响应码

// response.setStatus(404);
// response.sendError();

// response.setStatus(302);
// // 指定重定向的地址
// response.setHeader("Location", "http://www.baidu.com");
// 一行代码实现上面两行代码的功能
response.sendRedirect("http://www.baidu.com");

API简介之设置响应头

// 生成的头信息 : refresh: 3;url=http://www.baidu.com
// 3:代表3秒后跳转到一个新的页面
// url : 中的值代表的就是要跳转的页面
response.setHeader("refresh", "3;url=http://www.baidu.com");
// 设置响应内容的类型.客户端就知道发送过来的内容是什么类型的数据,使用对应的方式去解析数据
response.setContentType("");

API简介之设置响应体

protected void doGet(HttpServletRequest request, HttpServletResponse response)
		throws ServletException, IOException {
	// 编码格式不一致导致的
	// ISO-8859-1 Tomcat默认的码表
	// 指定了输出的内容使用什么码表进行编码.但是客户端不知道用什么码表进行解析
	// 如果客户端使用的码表正好和指定的码表是一致的,那就可以解析
	// 如果客户端使用的码表和指定的码表不一致,就还是不能解析
	// response.setCharacterEncoding("utf-8");
	// 指定输出的内容是什么类型的text/html
	// 指定了写回客户端的数据使用的是什么码表进行编码的UTF-8
	// 指定了客户端使用什么码表解析数据UTF-8
	// 如果要指定编码格式,一定要先指定,后输出内容
	response.setContentType("text/html;charset=UTF-8");
	// 这两个对象是互斥的,只能调用一个
	response.getWriter().write("你好");
	// response.getOutputStream().write("你好".getBytes());
}

案例1:下载

文件下载:将服务器上已经存在的文件,输出到客户端浏览器.

文件下载的方式:

第一种:超链接方式(不推荐)
        链接的方式:直接将服务器上的文件的路径写到href属性中.如果浏览器不支持该格式文件,那么就会提示进行下载, 如果浏览器支持这个格式的文件,那么直接打开


第二种:手动编码方式(推荐)
        手动编写代码实现下载.无论浏览器是否识别该格式的文件,都会提示下载.

 

设置两个头和一个流

​    设置的两个头:
        1.Content-Dispostion:浏览器识别该格式文件,提示下载.
//告诉浏览器去下载
response.setHeader("Content-Disposition", "attachment;filename="+filename);
        2.Content-Type:文件类型.(MIME的类型)  
//response.setHeader("Content-Type", mimeType);
response.setContentType(mimeType);
​     设置一个流:
         获得要下载的文件的输出流(字节流).
//得到输出流
OutputStream os = response.getOutputStream(  );

protected void doGet(HttpServletRequest request, HttpServletResponse response)
		throws ServletException, IOException {
	// 0.获取ServletContext
	ServletContext servletContext = getServletContext();
	// 1.获取用户需要下载的文件名
	String fileName = request.getParameter("file");
	// 2.要指定文件的Mime类型
	String mimeType = servletContext.getMimeType(fileName);
	response.setContentType(mimeType);
	// 3.指定如何处置这个文件
	// attachment: 代表要下载这个文件
	// filename: 代表下载这个文件的时候使用的默认文件名
	response.setHeader("Content-Disposition", "attachment; filename=" + fileName);
	// 4.以流的形式把文件写到客户端
	InputStream is = servletContext.getResourceAsStream("/" + fileName);
	ServletOutputStream os = response.getOutputStream();
	int len;
	byte[] buffer = new byte[1024];
	while ((len = is.read(buffer)) != -1) {
		os.write(buffer, 0, len);
	}
	is.close();
}

解决中文名

protected void doGet(HttpServletRequest request, HttpServletResponse response)
		throws ServletException, IOException {
	response.setContentType("text/html;charset=UTF-8");
	// 0.获取ServletContext
	ServletContext servletContext = getServletContext();
	// 1.获取用户需要下载的文件名
	String fileName = request.getParameter("file");
	// 2.要指定文件的Mime类型
	String mimeType = servletContext.getMimeType(fileName);
	response.setContentType(mimeType);
	// 3.指定如何处置这个文件
	// attachment: 代表要下载这个文件
	// filename: 代表下载这个文件的时候使用的默认文件名
	// 参数1:要进行编码的对象
	// 参数2:码表
	// String encode = URLEncoder.encode("附件", "utf-8");
	// 火狐浏览器编码方式是Base64,其他的浏览器编码方式使用的是utf-8
	// 获取客户端类型
	String agent = request.getHeader("User-Agent");
	String encode = DownLoadUtils.getName(agent, "附件");
	response.setHeader("Content-Disposition", "attachment; filename=" + encode + ".rar");
	// 4.以流的形式把文件写到客户端
	InputStream is = servletContext.getResourceAsStream("/" + fileName);
	ServletOutputStream os = response.getOutputStream();
	int len;
	byte[] buffer = new byte[1024];
	while ((len = is.read(buffer)) != -1) {
		os.write(buffer, 0, len);
	}
	is.close();
}

案例2:验证码

protected void doGet(HttpServletRequest request, HttpServletResponse response)
		throws ServletException, IOException {
	// 指定生成的验证码图片的宽度,单位像素
	int width = 120;
	// 指定生成的验证码图片的高度,单位像素
	int height = 40;
	// 指定生成的验证码图片中验证码的个数
	int codeCount = 4;
	// 指定生成的验证码图片中干扰线的个数
	int lineCount = 20;
	ValidateCode validateCode = new ValidateCode(width, height, codeCount, lineCount);
	validateCode.write(response.getOutputStream());
}

转载于:https://my.oschina.net/px828261/blog/1535461

### Spring Boot Response 使用方法 在 Spring Boot 应用程序中,`ResponseEntity<T>` 是一种常用的方式来自定义 HTTP 响应的状态码、头信息以及主体内容。这使得开发者能够灵活控制返回给客户端的信息。 对于简单的场景,可以直接从控制器方法返回 `String`, `void` 或者 POJO 对象。当返回这些类型的对象时,Spring MVC 会自动将其转换成 JSON 或 XML 形式的响应体[^2]。 然而,在更复杂的情况下,比如需要修改默认的行为或是添加额外的头部字段,则应该考虑使用 `HttpServletResponse` 参数或者封装到 `ResponseEntity<?>` 中去实现。下面是一个利用 `ResponseEntity<String>` 来构建自定义响应的例子: ```java @GetMapping("/custom-response") public ResponseEntity<String> customResponse() { HttpHeaders headers = new HttpHeaders(); headers.add("Custom-Header", "HeaderValue"); String body = "{ \"message\": \"This is a custom message\" }"; return new ResponseEntity<>(body, headers, HttpStatus.OK); } ``` 另外,为了满足某些特殊需求,可能还需要对原始的 `HttpServletResponse` 进行扩展或替换。由于直接操作 `HttpServletResponse` 的输出流存在局限性——即无法读取已经写出的数据——因此可以通过创建一个装饰器模式下的包装类来解决这个问题[^4]。 #### 自定义 HttpServletResponseWrapper 示例 通过继承 `HttpServletResponseWrapper` 类并覆盖相应的方法,可以在不改变原有接口的前提下增强功能。这里展示了一个简单版本的实现方式: ```java import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponseWrapper; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.OutputStream; // 定义一个新的 Wrapper 类 class CustomHttpResponse extends HttpServletResponseWrapper { private final ByteArrayOutputStream capture = new ByteArrayOutputStream(); public CustomHttpResponse(HttpServletResponse response) throws IOException { super(response); } @Override public OutputStream getOutputStream() throws IOException { return this.capture; // 替换原有的输出流为内存中的字节数组 } // 可以在此处添加更多逻辑... } // 控制器内调用此包装后的响应对象 @PostMapping("/wrap-response") @ResponseBody public void wrapResponse(HttpServletRequest request, HttpServletResponse response) throws Exception { try (var wrappedResp = new CustomHttpResponse(response)) { // 执行业务逻辑并将结果写入wrappedResp byte[] outputBytes = wrappedResp.getCapture().toByteArray(); // 获取最终要发送出去的内容 // 将捕获的数据重新设置回原responseresponse.getOutputStream().write(outputBytes); response.flushBuffer(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值