Servlet 3.1 发送 HTTP 状态码
HTTP 请求和 HTTP 响应消息的格式是类似的,结构如下:
- 初始状态行 + 回车换行符(回车+换行)
- 零个或多个标题行+回车换行符
- 一个空白行,即回车换行符
- 一个可选的消息主体,比如文件、查询数据或查询输出
例如,服务器的响应头如下所示:
HTTP/1.1 200 OK Content-Type: text/html Header2: ... ... HeaderN: ... (Blank Line) <!doctype ...> <html> <head>...</head> <body> ... </body> </html>
状态行包括 HTTP 版本(在本例中为 HTTP/1.1 )、一个状态码(在本例中为 200)和一个对应于状态码的短消息(在本例中为 OK)
HTTP 响应状态码
下表列出了 Web 服务器可能返回的 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 | 链接列表 用户可以选择一个链接,最多五个地址 |
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" 未定义 服务器无法处理不带 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 状态代码的方法
Java Servlet HttpServletResponse 类中的以下方法可以设置 HTTP 状态码
方法 & 描述 |
---|
public void setStatus ( int statusCode ) 设置一个任意的状态码。setStatus 方法接受一个 int(状态码)作为参数。如果您的反应包含了一个特殊的状态码和文档,请确保在使用PrintWriter实际返回任何内容之前调用 setStatus |
public void sendRedirect(String url) 生成一个 302 响应,连同一个带有新文档 URL 的 Location 头 |
public void sendError(int code, String message) 发送一个状态码(通常为 404),连同一个在 HTML 文档内部自动格式化并发送到客户端的短消息 |
范例
下面的范例演示了如何是使用 sendError 发送 407 错误码 和 "Need authentication!!!" 错误消息
// author: 简单教程(www.twle.cn) // Copyright © 2015-2065 www.twle.cn. All rights reserved. package cn.twle.demo; import java.io.*; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.WebServlet; import java.util.*; @WebServlet(name = "ShowErrorServlet", urlPatterns = {"show_error"}) public class ShowErrorServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 设置错误代码和原因 response.sendError(403, "www.twle.cn Need authentication!!!" ); // 设置响应内容类型 response.setContentType("text/html;charset=UTF-8"); } }
在浏览器上输入 http://localhost:8080/servlet/show_error 显示结果如下