Servlets 简明教程
Servlets - Server HTTP Response
如前一章所述,当 Web 服务器响应 HTTP 请求时,响应通常由状态行、一些响应头、一个空行和文档组成。一个典型的响应如下所示:
As discussed in the previous chapter, when a Web server responds to an HTTP request, the response typically consists of a status line, some response headers, a blank line, and the document. A typical response looks like this −
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)组成。
The status line consists of the HTTP version (HTTP/1.1 in the example), a status code (200 in the example), and a very short message corresponding to the status code (OK in the example).
以下是对最常用的 HTTP 1.1 响应头部的总结,这些响应头部从 Web 服务器端返回到浏览器,并且在 Web 编程中会非常频繁地使用:
Following is a summary of the most useful HTTP 1.1 response headers which go back to the browser from web server side and you would use them very frequently in web programming −
Sr.No. |
Header & Description |
1 |
Allow This header specifies the request methods (GET, POST, etc.) that the server supports. |
2 |
Cache-Control This header specifies the circumstances in which the response document can safely be cached. It can have values public, private or no-cache etc. Public means document is cacheable, Private means document is for a single user and can only be stored in private (non-shared) caches and nocache means document should never be cached. |
3 |
Connection This header instructs the browser whether to use persistent in HTTP connections or not. A value of close instructs the browser not to use persistent HTTP connections and keepalive means using persistent connections. |
4 |
Content-Disposition This header lets you request that the browser ask the user to save the response to disk in a file of the given name. |
5 |
Content-Encoding This header specifies the way in which the page was encoded during transmission. |
6 |
Content-Language This header signifies the language in which the document is written. For example en, en-us, ru, etc |
7 |
Content-Length This header indicates the number of bytes in the response. This information is needed only if the browser is using a persistent (keep-alive) HTTP connection. |
8 |
Content-Type This header gives the MIME (Multipurpose Internet Mail Extension) type of the response document. |
9 |
Expires This header specifies the time at which the content should be considered out-of-date and thus no longer be cached. |
10 |
Last-Modified This header indicates when the document was last changed. The client can then cache the document and supply a date by an If-Modified-Since request header in later requests. |
11 |
Location This header should be included with all responses that have a status code in the 300s. This notifies the browser of the document address. The browser automatically reconnects to this location and retrieves the new document. |
12 |
Refresh This header specifies how soon the browser should ask for an updated page. You can specify time in number of seconds after which a page would be refreshed. |
13 |
Retry-After This header can be used in conjunction with a 503 (Service Unavailable) response to tell the client how soon it can repeat its request. |
14 |
Set-Cookie This header specifies a cookie associated with the page. |
Methods to Set HTTP Response Header
可以使用以下方法在 servlet 程序中设置 HTTP 响应标头。这些方法可与 HttpServletResponse 对象一起使用。
There are following methods which can be used to set HTTP response header in your servlet program. These methods are available with HttpServletResponse object.
Sr.No. |
Method & Description |
1 |
String encodeRedirectURL(String url) Encodes the specified URL for use in the sendRedirect method or, if encoding is not needed, returns the URL unchanged. |
2 |
String encodeURL(String url) Encodes the specified URL by including the session ID in it, or, if encoding is not needed, returns the URL unchanged. |
3 |
boolean containsHeader(String name) Returns a Boolean indicating whether the named response header has already been set. |
4 |
*boolean isCommitted() * Returns a Boolean indicating if the response has been committed. |
5 |
void addCookie(Cookie cookie) Adds the specified cookie to the response. |
6 |
void addDateHeader(String name, long date) Adds a response header with the given name and date-value. |
7 |
void addHeader(String name, String value) Adds a response header with the given name and value. |
8 |
void addIntHeader(String name, int value) Adds a response header with the given name and integer value. |
9 |
*void flushBuffer() * Forces any content in the buffer to be written to the client. |
10 |
void reset() Clears any data that exists in the buffer as well as the status code and headers. |
11 |
void resetBuffer() Clears the content of the underlying buffer in the response without clearing headers or status code. |
12 |
void sendError(int sc) Sends an error response to the client using the specified status code and clearing the buffer. |
13 |
void sendError(int sc, String msg) Sends an error response to the client using the specified status. |
14 |
void sendRedirect(String location) Sends a temporary redirect response to the client using the specified redirect location URL. |
15 |
*void setBufferSize(int size) * Sets the preferred buffer size for the body of the response. |
16 |
void setCharacterEncoding(String charset) Sets the character encoding (MIME charset) of the response being sent to the client, for example, to UTF-8. |
17 |
*void setContentLength(int len) * Sets the length of the content body in the response In HTTP servlets, this method sets the HTTP Content-Length header. |
18 |
*void setContentType(String type) * Sets the content type of the response being sent to the client, if the response has not been committed yet. |
19 |
*void setDateHeader(String name, long date) * Sets a response header with the given name and date-value. |
20 |
*void setHeader(String name, String value) * Sets a response header with the given name and value. |
21 |
*void setIntHeader(String name, int value) * Sets a response header with the given name and integer value |
22 |
void setLocale(Locale loc) Sets the locale of the response, if the response has not been committed yet. |
23 |
*void setStatus(int sc) * Sets the status code for this response |
HTTP Header Response Example
您已经在前面的示例中看到 setContentType() 方法正在工作,并且后面的示例也会使用同样的方法,此外,我们会使用 setIntHeader() 方法来设置 Refresh 头。
You already have seen setContentType() method working in previous examples and following example would also use same method, additionally we would use setIntHeader() method to set Refresh header.
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class Refresh extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set refresh, autoload time as 5 seconds
response.setIntHeader("Refresh", 5);
// Set response content type
response.setContentType("text/html");
// Get current time
Calendar calendar = new GregorianCalendar();
String am_pm;
int hour = calendar.get(Calendar.HOUR);
int minute = calendar.get(Calendar.MINUTE);
int second = calendar.get(Calendar.SECOND);
if(calendar.get(Calendar.AM_PM) == 0)
am_pm = "AM";
else
am_pm = "PM";
String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
PrintWriter out = response.getWriter();
String title = "Auto Refresh Header Setting";
String docType =
"<!doctype html public \"-//w3c//dtd html 4.0 " + "transitional//en\">\n";
out.println(docType +
"<html>\n" +
"<head><title>" + title + "</title></head>\n"+
"<body bgcolor = \"#f0f0f0\">\n" +
"<h1 align = \"center\">" + title + "</h1>\n" +
"<p>Current Time is: " + CT + "</p>\n"
);
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
现在,调用上面的 servlet 将每隔 5 秒显示当前系统时间,如下所示。只需运行 servlet 并等待查看结果 -
Now calling the above servlet would display current system time after every 5 seconds as follows. Just run the servlet and wait to see the result −
Auto Refresh Header Setting
Current Time is: 9:44:50 PM