서블릿-클라이언트 HTTP 요청
브라우저가 웹 페이지를 요청할 때,이 정보는 HTTP 요청 헤더의 일부로 이동하기 때문에 직접 읽을 수없는 많은 정보를 웹 서버로 보냅니다. 이에 대한 자세한 내용은 HTTP 프로토콜 을 확인할 수 있습니다 .
다음은 브라우저 측에서 오는 중요한 헤더 정보이며 웹 프로그래밍에서 매우 자주 사용합니다.
Sr. 아니. | 헤더 및 설명 |
---|---|
1 | Accept 이 헤더는 브라우저 또는 다른 클라이언트가 처리 할 수있는 MIME 유형을 지정합니다. 가치image/png 또는 image/jpeg 가장 일반적인 두 가지 가능성입니다. |
2 | Accept-Charset 이 헤더는 브라우저가 정보를 표시하는 데 사용할 수있는 문자 세트를 지정합니다. 예 : ISO-8859-1. |
삼 | Accept-Encoding 이 헤더는 브라우저가 처리하는 방법을 알고있는 인코딩 유형을 지정합니다. 가치gzip 또는 compress 가장 일반적인 두 가지 가능성입니다. |
4 | Accept-Language 이 헤더는 서블릿이 둘 이상의 언어로 결과를 생성 할 수있는 경우 클라이언트의 선호 언어를 지정합니다. 예 : en, en-us, ru 등 |
5 | Authorization 이 헤더는 클라이언트가 암호로 보호 된 웹 페이지에 액세스 할 때 자신을 식별하는 데 사용됩니다. |
6 | Connection 이 헤더는 클라이언트가 지속적인 HTTP 연결을 처리 할 수 있는지 여부를 나타냅니다. 영구 연결을 사용하면 클라이언트 또는 기타 브라우저가 단일 요청으로 여러 파일을 검색 할 수 있습니다. 가치Keep-Alive 영구 연결을 사용해야 함을 의미합니다. |
7 | Content-Length 이 헤더는 POST 요청에만 적용되며 POST 데이터의 크기 (바이트)를 제공합니다. |
8 | Cookie 이 헤더는 쿠키를 이전에 브라우저로 보낸 서버로 반환합니다. |
9 | Host 이 헤더는 원래 URL에 제공된 호스트 및 포트를 지정합니다. |
10 | If-Modified-Since 이 헤더는 클라이언트가 지정된 날짜 이후에 변경된 경우에만 페이지를 원함을 나타냅니다. 서버는 코드 304를 보냅니다.Not Modified 최신 결과가없는 경우 헤더. |
11 | If-Unmodified-Since 이 헤더는 If-Modified-Since의 반대입니다. 문서가 지정된 날짜보다 오래된 경우에만 작업이 성공하도록 지정합니다. |
12 | Referer 이 헤더는 참조 웹 페이지의 URL을 나타냅니다. 예를 들어, 웹 페이지 1에서 웹 페이지 2에 대한 링크를 클릭하면 브라우저가 웹 페이지 2를 요청할 때 웹 페이지 1의 URL이 Referrer 헤더에 포함됩니다. |
13 | User-Agent 이 헤더는 요청을하는 브라우저 또는 다른 클라이언트를 식별하고 다른 콘텐츠를 다른 유형의 브라우저에 반환하는 데 사용할 수 있습니다. |
HTTP 헤더를 읽는 방법
서블릿 프로그램에서 HTTP 헤더를 읽는 데 사용할 수있는 방법은 다음과 같습니다. 이 메소드는 HttpServletRequest 객체 와 함께 사용할 수 있습니다.
Sr. 아니. | 방법 및 설명 |
---|---|
1 | Cookie[] getCookies() 클라이언트가이 요청과 함께 보낸 모든 Cookie 개체를 포함하는 배열을 반환합니다. |
2 | Enumeration getAttributeNames() 이 요청에 사용할 수있는 속성의 이름이 포함 된 열거를 반환합니다. |
삼 | Enumeration getHeaderNames() 이 요청에 포함 된 모든 헤더 이름의 열거 형을 반환합니다. |
4 | Enumeration getParameterNames() 이 요청에 포함 된 매개 변수의 이름을 포함하는 String 객체의 열거 형을 반환합니다. |
5 | HttpSession getSession() 이 요청과 관련된 현재 세션을 반환하거나 요청에 세션이없는 경우 하나를 만듭니다. |
6 | HttpSession getSession(boolean create) 이 요청과 관련된 현재 HttpSession을 반환하거나 현재 세션이없고 create 값이 true 인 경우 새 세션을 반환합니다. |
7 | Locale getLocale() Accept-Language 헤더를 기반으로 클라이언트가 콘텐츠를 수락 할 선호하는 Locale을 반환합니다. |
8 | Object getAttribute(String name) 명명 된 속성의 값을 Object로 반환하거나 지정된 이름의 속성이없는 경우 null을 반환합니다. |
9 | ServletInputStream getInputStream() ServletInputStream을 사용하여 이진 데이터로 요청 본문을 검색합니다. |
10 | String getAuthType() 서블릿을 보호하는 데 사용되는 인증 체계의 이름 (예 : "BASIC"또는 "SSL")을 반환하거나 JSP가 보호되지 않은 경우 null을 반환합니다. |
11 | String getCharacterEncoding() 이 요청의 본문에 사용 된 문자 인코딩의 이름을 반환합니다. |
12 | String getContentType() 요청 본문의 MIME 유형을 반환하거나 유형을 알 수없는 경우 null을 반환합니다. |
13 | String getContextPath() 요청의 컨텍스트를 나타내는 요청 URI 부분을 반환합니다. |
14 | String getHeader(String name) 지정된 요청 헤더의 값을 문자열로 반환합니다. |
15 | String getMethod() 이 요청에 사용 된 HTTP 메서드의 이름 (예 : GET, POST 또는 PUT)을 반환합니다. |
16 | String getParameter(String name) 요청 매개 변수의 값을 문자열로 반환하거나 매개 변수가없는 경우 null을 반환합니다. |
17 | String getPathInfo() 이 요청을 할 때 클라이언트가 보낸 URL과 관련된 추가 경로 정보를 반환합니다. |
18 | String getProtocol() 요청한 프로토콜의 이름과 버전을 반환합니다. |
19 | String getQueryString() 경로 뒤의 요청 URL에 포함 된 쿼리 문자열을 반환합니다. |
20 | String getRemoteAddr() 요청을 보낸 클라이언트의 IP (인터넷 프로토콜) 주소를 반환합니다. |
21 | String getRemoteHost() 요청을 보낸 클라이언트의 정규화 된 이름을 반환합니다. |
22 | String getRemoteUser() 사용자가 인증 된 경우이 요청을하는 사용자의 로그인을 반환하고, 사용자가 인증되지 않은 경우 null을 반환합니다. |
23 | String getRequestURI() 프로토콜 이름에서 HTTP 요청의 첫 번째 줄에있는 쿼리 문자열까지이 요청의 URL 부분을 반환합니다. |
24 | String getRequestedSessionId() 클라이언트가 지정한 세션 ID를 반환합니다. |
25 | String getServletPath() JSP를 호출하는이 요청의 URL 부분을 리턴합니다. |
26 | String[] getParameterValues(String name) 지정된 요청 매개 변수에있는 모든 값을 포함하는 String 객체의 배열을 반환하거나 매개 변수가없는 경우 null을 반환합니다. |
27 | boolean isSecure() 이 요청이 HTTPS와 같은 보안 채널을 사용하여 만들어 졌는지 여부를 나타내는 부울을 반환합니다. |
28 | int getContentLength() 입력 스트림에서 사용할 수있는 요청 본문의 길이 (바이트)를 반환하거나 길이를 알 수없는 경우 -1을 반환합니다. |
29 | int getIntHeader(String name) 지정된 요청 헤더의 값을 int로 반환합니다. |
30 | int getServerPort() 이 요청이 수신 된 포트 번호를 반환합니다. |
HTTP 헤더 요청 예
다음은 사용하는 예입니다. getHeaderNames()HTTP 헤더 정보를 읽기위한 HttpServletRequest의 메소드. 이 메서드는 현재 HTTP 요청과 관련된 헤더 정보가 포함 된 Enumeration을 반환합니다.
Enumeration이 있으면 표준 방식으로 Enumeration을 반복 할 수 있습니다. hasMoreElements () 메서드를 사용하여 중지 할시 기를 결정하고 nextElement () 메서드를 사용하여 각 매개 변수 이름을 가져옵니다.
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Extend HttpServlet class
public class DisplayHeader extends HttpServlet {
// Method to handle GET method request.
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// Set response content type
response.setContentType("text/html");
PrintWriter out = response.getWriter();
String title = "HTTP Header Request Example";
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" +
"<table width = \"100%\" border = \"1\" align = \"center\">\n" +
"<tr bgcolor = \"#949494\">\n" +
"<th>Header Name</th><th>Header Value(s)</th>\n"+
"</tr>\n"
);
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");
}
out.println("</table>\n</body></html>");
}
// Method to handle POST method request.
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}
이제 위의 서블릿을 호출하면 다음 결과가 생성됩니다.
HTTP Header Request Example
Header Name
Header Value(s)
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