Khi một trình duyệt yêu cầu một Webpage, nó gửi nhiều thông tin tới Web server, mà không thể được đọc một cách trực tiếp bởi vì thông tin này là một phần trong Header của HTTP request. Bạn có thể truy cập chương: Giao thức HTTP để theo dõi chi tiết về điều này.
Dưới đây là các thông tin header quan trọng mà tới từ Brower Side mà bạn sẽ sử dụng thường xuyên trong lập trình web.
Header | Miêu tả |
---|---|
Accept | Trường này xác định loại MIME mà trình duyệt hoặc Client khác có thể xử lý. Các giá trị image/png hoặc image/jpeg là hai khả năng phổ biến nhất |
Accept-Charset | Trường này xác định bộ ký tự mà trình duyệt có thể sử dụng để hiển thị thông tin. Ví dụ: ISO-8859-1 |
Accept-Encoding | Trường này xác định kiểu mã hóa mà trình duyệt biết để xử lý. Các giá trị của gzip hoặc compress là hai khả năng phổ biến nhất |
Accept-Language | Trường này xác định ngôn ngữ ưa thíc của Client trong trường hợp Servlet có thể tạo các kết quả trong nhiều ngôn ngữ. Ví dụ en, en-us, ru, .v.v. |
Authorization | Trường này được sử dụng bởi Client để nhận diện chính nó khi truy cập vào các trang web được bảo vệ bởi password |
Connection | Trường này chỉ dẫn có hay không Client có thể xử lý các kết nối HTTP dạng Persistent. Các kết nối Persistent cho phép Client hoặc trình duyệt thu nhận nhiều file với một yêu cầu đơn. Một giá trị của Keep-Alive nghĩa là các kết nối Persistent này nên được sử dụng |
Content-Length | Trường này chỉ thích hợp với các yêu cầu POST và cung cấp kích cỡ của dữ liệu POST bằng giá trị byte |
Cookie | Trường này trả về các cookie tới các Server mà trước đó đã gửi chúng tới trình duyệt |
Host | Trường này xác định host và cổng (port) khi được cung cấp trong URL ban đầu |
If-Modified-Since | Trường này chỉ rằng Client muốn trang này chỉ khi nó đã được thay đổi sau ngày đã xác định. Server gửi một code là 304, nghĩa là Not Modified Header nếu không có kết quả nào mới hơn là có sẵn |
If-Unmodified-Since | Trường này là ngược với trường If-Modified-Since. Nó xác định hoạt động là thành công chỉ khi tài liệu là cũ hơn ngày đã xác định |
Referer | Trường này chỉ URL của trang web đang tham chiếu đó. Ví dụ, nếu bạn tại trang Webpage 1 và click vào một link tới trang Webpage 2, thì URL của Webpage 1 được bao trong trường Referer Header khi trình duyệt yêu cầu trang Webpage 2 |
User-Agent | Trường này nhận diện trình duyệt hoặc Client đang tạo yêu cầu và có thể được sử dụng để trả về nội dung khác nhau cho các loại trình duyệt khác nhau |
Đối tượng HttpServletRequest trong JSP
Đối tượng request là một minh họa của một đối tượng javax.servlet.http.HttpServletRequest. Mỗi khi một Client yêu cầu một trang, thì JSP engine tạo một đối tượng mới để biểu diễn yêu cầu đó.
Đối tượng request cung cấp các phương thức để nhận thông tin HTTP header gồm Form data, cookie, phương thức HTTP, …
Bảng dưới liệt kê các phương thức quan trọng có thể được sử dụng để đọc HTTP header trong chương trình JSP của bạn. Các phương thức này có sẵn với đối tượng HttpServletRequest mà biểu diễn Client Request tới Webserver.
STT | Phương thức & Miêu tả |
---|---|
1 | Cookie[] getCookies() Trả về một mảng chứa tất cả đối tượng Cookie mà Client gửi với yêu cầu này |
2 | Enumeration getAttributeNames() Trả về một Enumeration chứa các tên của thuộc tính có sẵn cho yêu cầu này |
3 | Enumeration getHeaderNames() Trả về một Enumeration của tất cả tên Header mà yêu cầu này chứa |
4 | Enumeration getParameterNames() Trả về một Enumeration của các đối tượng String chứa tên của Parameter được chứa trong yêu cầu này |
5 | HttpSession getSession() Trả về session hiện tại, mà liên kết với yêu cầu này, hoặc yêu cầu đó không có một session, nó sẽ tạo ra một session |
6 | HttpSession getSession(boolean create) Trả về HttpSession hiện tại, mà liên kết với yêu cầu này, hoặc nếu không có session hiện tại nào và create là true, nó trả về một session mới |
7 | Locale getLocale() Trả về Locale mà Client sẽ chấp chận nội dung trong đó, dựa trên trường Accept-Language Header |
8 | Object getAttribute(String name) Trả về giá trị của thuộc tính name như là một Object, hoặc trả về null nếu không có thuộc tính nào trong name đã cung cấp tồn tại |
9 | ServletInputStream getInputStream() Thu nhận thân yêu cầu dạng dữ liệu nhị phân bởi sử dụng một ServletInputStream |
10 | String getAuthType() Trả về tên của Authentication Scheme được sử dụng để bảo vệ Servlet, ví dụ: "BASIC" hoặc "SSL", hoặc trả về null nếu JSP không được bảo vệ |
11 | String getCharacterEncoding() Trả về tên của Mã hóa ký tự được sử dụng trong thân yêu cầu này |
12 | String getContentType() Trả về kiểu MIME của thân yêu cầu, hoặc trả về null nếu không biết kiểu này |
13 | String getContextPath() Trả về phần URI yêu cầu mà chỉ dẫn context của yêu cầu đó |
14 | String getHeader(String name) Trả về giá trị của trường Header đã xác định dưới dạng một String |
15 | String getMethod() Trả về tên của phương thức HTTP mà yêu cầu này được tạo, ví dụ: GET, POST, hoặc PUT |
16 | String getParameter(String name) Trả về giá trị của Parameter dưới dạng một String, hoặc trả về null nếu Parameter này không tồn tại |
17 | String getPathInfo() Trả về bất kỳ thông tin path bổ sung, mà liên kết với URI mà Client đã gửi khi nó tạo yêu cầu này |
18 | String getProtocol() Trả về tên và phiên bản của giao thức |
19 | String getQueryString() Trả về chuỗi truy vấn, được chứa trong URL sau path đó |
20 | String getRemoteAddr() Trả về địa chỉ Internet Protocol (IP) của một Client mà gửi yêu cầu này |
21 | String getRemoteHost() Trả về tên đầy đủ của Client mà gửi yêu cầu này |
22 | String getRemoteUser() Trả về login của người sử dụng tạo yêu cầu này, nếu người dùng đã được xác nhận, hoặc trả về null nếu người dùng chưa được xác nhận |
23 | String getRequestURI() Trả về phần URL của yêu cầu này từ tên giao thức dưới dạng một chuỗi truy vấn trong dòng đầu tiên của HTTP Request |
24 | String getRequestedSessionId() Trả về ID của session đã được xác định bởi Client |
25 | String getServletPath() Trả về phần URL của yêu cầu này mà gọi JSP |
26 | String[] getParameterValues(String name) Trả về một mảng đối tượng String chứa tất cả các giá trị mà các parameter đã cung cấp có, hoặc trả về null nếu parameter này không tồn tại |
27 | boolean isSecure() Trả về một Boolean chỉ rằng có hay không yêu cầu này được tạo bởi sử dụng một đường an toàn, như HTTPS |
28 | int getContentLength() Trả về độ dài, bằng giá trị byte, của thân yêu cầu và làm nó có sẵn bởi Input Stream, hoặc trả về -1 nếu độ dài là không được biết |
29 | int getIntHeader(String name) Trả về giá trị của Request header đã cho dưới dạng một int |
30 | int getServerPort() Trả về số hiệu cổng mà trên đó yêu cầu được nhận |
Ví dụ HTTP Header Request trong JSP
Ví dụ sau sử dụng phương thức getHeaderName() của đối tượng HttpServletRequest để đọc thông tin HTTP header. Phương thức này trả về một Enumeration chứa thông tin header mà liên kết với HTTP request hiện tại.
Khi chúng ta có một Enumeration, chúng ta có thể lặp Enumeration này theo phương thức chuẩn: sử dụng phương thức hasMoreElements() để xác định khi nào dừng và sử dụng phương thức nextElement() để nhận tên mỗi parameter.
<%@ page import="java.io.*,java.util.*" %>
<html>
<head>
<title>HTTP Header Request Example</title>
</head>
<body>
<center>
<h2>HTTP Header Request Example</h2>
<table width="100%" border="1" align="center">
<tr bgcolor="#949494">
<th>Header Name</th><th>Header Value(s)</th>
</tr>
<%
Enumeration headerNames = request.getHeaderNames();
while(headerNames.hasMoreElements()) {
String paramName = (String)headerNames.nextElement();
out.print("<tr><td>" + paramName + "</td>\n");
String paramValue = request.getHeader(paramName);
out.println("<td> " + paramValue + "</td></tr>\n");
}
%>
</table>
</center>
</body>
</html>
Bây giờ đặt code trên trong main.jsp và thử truy cập nó. Nó sẽ cho kết quả sau:
Tên và giá trị tương ứng của HTTP Header Request trong JSP
Tên Header | Giá trị Header |
---|---|
accept | */* |
accept-language | en-us |
user-agent | Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; InfoPath.2; MS-RTC LM 8) |
accept-encoding | gzip, deflate |
host | localhost:8080 |
connection | Keep-Alive |
cache-control | no-cache |