JSP 服务器响应
Response响应对象主要将JSP容器处理后的结果传回到客户端。
可以通过response变量设置HTTP的状态和向客户端发送数据,如Cookie、HTTP文件头信息等。
一个典型的响应看起来就像下面这样:
HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
(空行)
<!doctype ...>
<html>
<head>...</head>
<body>
...
</body>
</html>
状态行包含HTTP版本信息,比如HTTP/1.1,一个状态码,比如200,还有一个非常短的信息对应着状态码,比如OK。
响应头主要属性
下表摘要出了HTTP1.1响应头中最有用的部分,在网络编程中您将会经常见到它们:
响应头 | 描述 |
---|---|
Allow | 指定服务器支持的request方法(GET,POST等等) |
Cache-Control | 指定响应文档能够被安全缓存的情况。通常取值为 public,private 或no-cache 等等。 Public意味着文档可缓存,Private意味着文档只为单用户服务并且只能使用私有缓存。No-cache 意味着文档不被缓存。 |
Connection | 命令浏览器是否要使用持久的HTTP连接。close值 命令浏览器不使用持久HTTP连接,而keep-alive 意味着使用持久化连接。 |
Content-Disposition | 让浏览器要求用户将响应以给定的名称存储在磁盘中 |
Content-Encoding | 指定传输时页面的编码规则 |
Content-Language | 表述文档所使用的语言,比如en, en-us,,ru等等 |
Content-Length | 表明响应的字节数。只有在浏览器使用持久化 (keep-alive) HTTP 连接时才有用 |
Content-Type | 表明文档使用的MIME类型 |
Expires | 指明啥时候过期并从缓存中移除 |
Last-Modified | 指明文档最后修改时间。客户端可以 缓存文档并且在后续的请求中提供一个 If-Modified-Since请求头 |
Location | 在300秒内,包含所有的有一个状态码的响应地址,浏览器会自动重连然后检索新文档 |
Refresh | 指明浏览器每隔多久请求更新一次页面。 |
Retry-After | 与503 (Service Unavailable)一起使用来告诉用户多久后请求将会得到响应 |
Set-Cookie | 指明当前页面对应的cookie |
HttpServletResponse类
response 对象是 javax.servlet.http.HttpServletResponse 类的一个实例。
就像服务器会创建request对象一样,它也会创建一个客户端响应。
response对象定义了处理创建HTTP信息头的接口。通过使用这个对象,开发者们可以添加新的cookie或时间戳,还有HTTP状态码等等。
下表列出了用来设置HTTP响应头的方法,这些方法由HttpServletResponse 类提供:
方法 | 描述 |
---|---|
String encodeRedirectURL(String url) | 对sendRedirect()方法使用的URL进行编码 |
String encodeURL(String url) | 将URL编码,回传包含Session ID的URL |
boolean containsHeader(String name) | 返回指定的响应头是否存在 |
boolean isCommitted() | 返回响应是否已经提交到客户端 |
void addCookie(Cookie cookie) | 添加指定的cookie至响应中 |
void addDateHeader(String name, long date) | 添加指定名称的响应头和日期值 |
void addHeader(String name, String value) | 添加指定名称的响应头和值 |
void addIntHeader(String name, int value) | 添加指定名称的响应头和int值 |
void flushBuffer() | 将任何缓存中的内容写入客户端 |
void reset() | 清除任何缓存中的任何数据,包括状态码和各种响应头 |
void resetBuffer() | 清除基本的缓存数据,不包括响应头和状态码 |
void sendError(int sc) | 使用指定的状态码向客户端发送一个出错响应,然后清除缓存 |
void sendError(int sc, String msg) | 使用指定的状态码和消息向客户端发送一个出错响应 |
void sendRedirect(String location) | 使用指定的URL向客户端发送一个临时的间接响应 |
void setBufferSize(int size) | 设置响应体的缓存区大小 |
void setCharacterEncoding(String charset) | 指定响应的编码集(MIME字符集),例如UTF-8 |
void setContentLength(int len) | 指定HTTP servlets中响应的内容的长度,此方法用来设置 HTTP Content-Length 信息头 |
void setContentType(String type) | 设置响应的内容的类型,如果响应还未被提交的话 |
void setDateHeader(String name, long date) | 使用指定名称和值设置响应头的名称和内容 |
void setHeader(String name, String value) | 使用指定名称和值设置响应头的名称和内容 |
void setIntHeader(String name, int value) | 指定 int 类型的值到 name 标头 |
void setLocale(Locale loc) | 设置响应的语言环境,如果响应尚未被提交的话 |
void setStatus(int sc) | 设置响应的状态码 |
HTTP响应头程序示例
前端
接下来的例子使用setIntHeader()方法和setRefreshHeader()方法来模拟一个数字时钟:
<%@ page import="java.util.Enumeration" %>
<%@ page import="java.util.Date" %>
<!DOCTYPE html>
<%@page contentType="text/html; charset=UTF-8" language="java"%>
<html lang="zh">
<head>
<title>JSP REQUEST</title>
</head>
<body>
<h2>自动刷新实例</h2>
<%
//5s 自动刷新一次
response.setIntHeader("Refresh", 5);
// 显示当前时间
out.println("当前时间: " + new Date().toLocaleString());
%>
</body>
</html>
后端
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@Controller
@RequestMapping("/response")
public class ResponseController {
@RequestMapping("/auto")
public String request(HttpServletRequest request,
HttpServletResponse response) {
return "autoRefresh";
}
}
效果
页面访问:http://localhost:8080/response/auto
自动刷新实例
当前时间: 2020-8-30 16:04:10
每 5S 钟会刷新一次时间。
HTTP 状态码
HTTP请求与HTTP响应的格式相近,都有着如下结构:
结构
-
以状态行+CRLF(回车换行)开始
-
零行或多行头模块+CRLF
-
一个空行,比如CRLF
-
可选的消息体比如文件,查询数据,查询输出
例子
举例来说,一个服务器响应头看起来就像下面这样:
HTTP/1.1 200 OK
Content-Type: text/html
Header2: ...
...
HeaderN: ...
(Blank Line)
<!doctype ...>
<html>
<head>...</head>
<body>
...
</body>
</html>
状态行包含HTTP版本,一个状态码,和状态码相对应的短消息。
HTTP 状态码
下表列出了可能会从服务器返回的HTTP状态码和与之关联的消息:
状态码 消息 描述
100 Continue 只有一部分请求被服务器接收,但只要没被服务器拒绝,客户端就会延续这个请求
101 Switching Protocols 服务器交换机协议
200 OK 请求被确认
201 Created 请求时完整的,新的资源被创建
202 Accepted 请求被接受,但未处理完
203 Non-authoritative Information
204 No Content
205 Reset Content
206 Partial Content
300 Multiple Choices 一个超链接表,用户可以选择一个超链接并访问,最大支持5个超链接
301 Moved Permanently 被请求的页面已经移动到了新的URL下
302 Found 被请求的页面暂时性地移动到了新的URL下
303 See Other 被请求的页面可以在一个不同的URL下找到
304 Not Modified
305 Use Proxy
306 Unused 已经不再使用此状态码,但状态码被保留
307 Temporary Redirect 被请求的页面暂时性地移动到了新的URL下
400 Bad Request 服务器无法识别请求
401 Unauthorized 被请求的页面需要用户名和密码
402 Payment Required 目前还不能使用此状态码
403 Forbidden 禁止访问所请求的页面
404 Not Found 服务器无法找到所请求的页面
405 Method Not Allowed 请求中所指定的方法不被允许
406 Not Acceptable 服务器只能创建一个客户端无法接受的响应
407 Proxy Authentication Required 在请求被服务前必须认证一个代理服务器
408 Request Timeout 请求时间超过了服务器所能等待的时间,连接被断开
409 Conflict 请求有矛盾的地方
410 Gone 被请求的页面不再可用
411 Length Required "Content-Length"没有被定义,服务器拒绝接受请求
412 Precondition Failed 请求的前提条件被服务器评估为false
413 Request Entity Too Large 因为请求的实体太大,服务器拒绝接受请求
414 Request-url Too Long 服务器拒绝接受请求,因为URL太长。多出现在把"POST"请求转换为"GET"请求时所附带的大量查询信息
415 Unsupported Media Type 服务器拒绝接受请求,因为媒体类型不被支持
417 Expectation Failed
500 Internal Server Error 请求不完整,服务器遇见了出乎意料的状况
501 Not Implemented 请求不完整,服务器不提供所需要的功能
502 Bad Gateway 请求不完整,服务器从上游服务器接受了一个无效的响应
503 Service Unavailable 请求不完整,服务器暂时重启或关闭
504 Gateway Timeout 网关超时
505 HTTP Version Not Supported 服务器不支持所指定的HTTP版本
设置HTTP状态码的方法
下表列出了HttpServletResponse 类中用来设置状态码的方法:
方法 | 描述 |
---|---|
public void setStatus (int statusCode) | 方法可以设置任意的状态码。如果您的响应包含一个特殊的状态码和一个文档,请确保在用PrintWriter返回任何内容前调用setStatus方法 |
public void sendRedirect(String url) | 此方法产生302响应,同时产生一个 Location 头告诉URL 一个新的文档 |
public void sendError(int code, String message) | 此方法将一个状态码(通常为 404)和一个短消息,自动插入HTML文档中并发回给客户端 |
HTTP状态码程序示例
接下来的例子将会发送407错误码给浏览器,然后浏览器将会告诉您”Need authentication!!!”。
前端
<html>
<head>
<title>Setting HTTP Status Code</title>
</head>
<body>
<%
// 设置错误代码,并说明原因
response.sendError(407, "Need authentication!!!" );
%>
</body>
</html>
访问效果
无法访问此网站网址为 http://localhost:8080/response/auth 的网页可能暂时无法连接,或者它已永久性地移动到了新网址。
ERR_UNEXPECTED_PROXY_AUTH
参考资料
https://www.runoob.com/jsp/jsp-server-response.html
https://www.runoob.com/jsp/jsp-http-status-codes.html