14/08/2018, 10:49

Client Request trong JSP

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 ...

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.

HeaderMiêu tả
AcceptTrườ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-CharsetTrườ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-EncodingTrườ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-LanguageTrườ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.
AuthorizationTrườ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
ConnectionTrườ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-LengthTrườ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
CookieTrườ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
HostTrường này xác định host và cổng (port) khi được cung cấp trong URL ban đầu
If-Modified-SinceTrườ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-SinceTrườ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
RefererTrườ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-AgentTrườ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.

STTPhươ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 awidth="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>
");
      String paramValue = request.getHeader(paramName);
      out.println("<td> " + paramValue + "</td></tr>
");
   }
%>
</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 HeaderGiá 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

Để làm quen với các phương thức này, bạn thử viết các chương trình sử dụng các phương thức trên theo cách thức tương tự trên.

0