सर्वलेट्स - सर्वर 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), और स्टेटस कोड (उदाहरण में ओके) के अनुरूप एक बहुत छोटा संदेश होता है।
निम्नलिखित सबसे उपयोगी HTTP 1.1 प्रतिक्रिया हेडर का सारांश है जो वेब सर्वर की ओर से ब्राउज़र में वापस जाता है और आप वेब प्रोग्रामिंग में उनका बहुत बार उपयोग करेंगे -
अनु क्रमांक। | हेडर और विवरण |
---|---|
1 | Allow यह शीर्ष लेख अनुरोध विधियों (GET, POST, आदि) को निर्दिष्ट करता है जो सर्वर समर्थन करता है। |
2 | Cache-Control यह शीर्ष लेख उन परिस्थितियों को निर्दिष्ट करता है जिसमें प्रतिक्रिया दस्तावेज़ सुरक्षित रूप से कैश किया जा सकता है। इसके मान हो सकते हैंpublic, private या no-cache आदि का अर्थ है कि सार्वजनिक दस्तावेज दस्तावेज़ उपलब्ध नहीं है, निजी साधन दस्तावेज़ एकल उपयोगकर्ता के लिए है और इसे केवल निजी (गैर-साझा) कैश में संग्रहित किया जा सकता है और नोचे का अर्थ है कि दस्तावेज़ को कभी कैश नहीं किया जाना चाहिए। |
3 | Connection यह हेडर ब्राउज़र को निर्देश देता है कि क्या HTTP कनेक्शन में लगातार उपयोग करना है या नहीं। का एक मूल्यclose ब्राउज़र को लगातार HTTP कनेक्शन का उपयोग न करने का निर्देश देता है और keepalive लगातार कनेक्शन का उपयोग करने का मतलब है। |
4 | Content-Disposition यह हेडर आपको अनुरोध करता है कि ब्राउज़र उपयोगकर्ता को दिए गए नाम की फ़ाइल में डिस्क की प्रतिक्रिया को बचाने के लिए कहें। |
5 | Content-Encoding यह शीर्ष लेख उस तरीके को निर्दिष्ट करता है जिसमें ट्रांसमिशन के दौरान पृष्ठ एन्कोड किया गया था। |
6 | Content-Language यह हेडर उस भाषा को दर्शाता है जिसमें दस्तावेज़ लिखा गया है। उदाहरण के लिए एन, एन-यू, आरयू, आदि |
7 | Content-Length यह हेडर प्रतिक्रिया में बाइट्स की संख्या को इंगित करता है। यह जानकारी केवल तभी आवश्यक है जब ब्राउज़र एक निरंतर (चालू-जीवित) HTTP कनेक्शन का उपयोग कर रहा है। |
8 | Content-Type यह हेडर प्रतिक्रिया दस्तावेज़ के MIME (बहुउद्देशीय इंटरनेट मेल एक्सटेंशन) प्रकार देता है। |
9 | Expires यह शीर्ष लेख उस समय को निर्दिष्ट करता है जिस पर सामग्री को पुराना माना जाना चाहिए और इस प्रकार अब कैश नहीं किया जाना चाहिए। |
10 | Last-Modified यह हेडर इंगित करता है कि दस्तावेज़ अंतिम बार कब बदला गया था। ग्राहक तब दस्तावेज़ को कैश कर सकता है और एक तारीख को आपूर्ति कर सकता हैIf-Modified-Since बाद के अनुरोधों में हेडर का अनुरोध करें। |
1 1 | Location इस हैडर को उन सभी प्रतिक्रियाओं के साथ शामिल किया जाना चाहिए जिनके पास 300 में एक स्थिति कोड है। यह दस्तावेज़ पते के ब्राउज़र को सूचित करता है। ब्राउज़र स्वचालित रूप से इस स्थान पर फिर से जुड़ता है और नए दस्तावेज़ को पुनः प्राप्त करता है। |
12 | Refresh यह हेडर निर्दिष्ट करता है कि ब्राउज़र को अद्यतन पृष्ठ के लिए कितनी जल्दी पूछना चाहिए। आप कुछ सेकंड में समय निर्दिष्ट कर सकते हैं जिसके बाद एक पृष्ठ ताज़ा किया जाएगा। |
13 | Retry-After इस हेडर का उपयोग क्लाइंट को बताने के लिए 503 (सेवा अनुपलब्ध) प्रतिक्रिया के साथ संयोजन के रूप में किया जा सकता है कि वह कितनी जल्दी अपने अनुरोध को दोहरा सकता है। |
14 | Set-Cookie यह शीर्षलेख पृष्ठ से संबद्ध कुकी निर्दिष्ट करता है। |
HTTP रिस्पांस हैडर सेट करने के तरीके
निम्नलिखित तरीके हैं जो आपके सर्वलेट प्रोग्राम में HTTP प्रतिक्रिया हेडर सेट करने के लिए उपयोग किए जा सकते हैं। ये तरीके HttpServletResponse ऑब्जेक्ट के साथ उपलब्ध हैं ।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | String encodeRedirectURL(String url) SendRedirect विधि में उपयोग के लिए निर्दिष्ट URL को एन्कोड करता है या, यदि एन्कोडिंग की आवश्यकता नहीं है, तो URL को अपरिवर्तित लौटाता है। |
2 | String encodeURL(String url) इसमें सत्र आईडी शामिल करके निर्दिष्ट URL को एनकोड करता है, या, यदि एन्कोडिंग की आवश्यकता नहीं है, तो URL अपरिवर्तित लौटाता है। |
3 | boolean containsHeader(String name) एक बूलियन को इंगित करता है कि नामांकित शीर्ष लेख पहले ही सेट किया गया है। |
4 | boolean isCommitted() यदि प्रतिक्रिया हुई है तो यह इंगित करते हुए एक बूलियन लौटाता है। |
5 | void addCookie(Cookie cookie) निर्दिष्ट कुकी को प्रतिक्रिया में जोड़ता है। |
6 | void addDateHeader(String name, long date) दिए गए नाम और दिनांक-मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
7 | void addHeader(String name, String value) दिए गए नाम और मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
8 | void addIntHeader(String name, int value) दिए गए नाम और पूर्णांक मान के साथ एक प्रतिक्रिया शीर्ष लेख जोड़ता है। |
9 | void flushBuffer() क्लाइंट को लिखी जाने वाली बफर की किसी भी सामग्री को मजबूर करता है। |
10 | void reset() बफर में मौजूद किसी भी डेटा को क्लियर करने के साथ-साथ स्टेटस कोड और हेडर। |
1 1 | void resetBuffer() हेडर या स्थिति कोड को साफ़ किए बिना प्रतिक्रिया में अंतर्निहित बफर की सामग्री को साफ करता है। |
12 | void sendError(int sc) निर्दिष्ट स्थिति कोड का उपयोग करके क्लाइंट को एक त्रुटि प्रतिक्रिया भेजता है और बफर को साफ़ करता है। |
13 | void sendError(int sc, String msg) निर्दिष्ट स्थिति का उपयोग करके क्लाइंट को एक त्रुटि प्रतिक्रिया भेजता है। |
14 | void sendRedirect(String location) निर्दिष्ट रीडायरेक्ट स्थान URL का उपयोग करके क्लाइंट को एक अस्थायी पुनर्निर्देशित प्रतिक्रिया भेजता है। |
15 | void setBufferSize(int size) प्रतिक्रिया के शरीर के लिए पसंदीदा बफर आकार सेट करता है। |
16 | void setCharacterEncoding(String charset) क्लाइंट को भेजे जा रहे रिस्पॉन्स के कैरेक्टर एन्कोडिंग (MIME चार्जसेट) को सेट करता है, उदाहरण के लिए, UTF-8 को। |
17 | void setContentLength(int len) प्रतिक्रिया में सामग्री निकाय की लंबाई सेट करता है HTTP सर्वलेट्स में, यह विधि HTTP सामग्री-लंबाई शीर्ष लेख सेट करती है। |
18 | void setContentType(String type) ग्राहक को भेजी जा रही प्रतिक्रिया का सामग्री प्रकार सेट करता है, अगर प्रतिक्रिया अभी तक प्रतिबद्ध नहीं हुई है। |
19 | void setDateHeader(String name, long date) दिए गए नाम और दिनांक-मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है। |
20 | void setHeader(String name, String value) दिए गए नाम और मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है। |
21 | void setIntHeader(String name, int value) दिए गए नाम और पूर्णांक मान के साथ एक प्रतिक्रिया शीर्षलेख सेट करता है |
22 | void setLocale(Locale loc) प्रतिक्रिया का स्थान निर्धारित करता है, अगर प्रतिक्रिया अभी तक प्रतिबद्ध नहीं हुई है। |
23 | void setStatus(int sc) इस प्रतिक्रिया के लिए स्थिति कोड सेट करता है |
HTTP हैडर रिस्पांस उदाहरण
आप पहले से ही setContentType () विधि को पिछले उदाहरणों में काम करते हुए देख चुके हैं और निम्नलिखित उदाहरण भी उसी विधि का उपयोग करेंगे, इसके अतिरिक्त हम उपयोग करेंगे setIntHeader() सेट करने की विधि Refresh हैडर।
// 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);
}
}
अब उपरोक्त सर्वलेट को कॉल करने पर निम्न 5 सेकंड के बाद वर्तमान सिस्टम समय प्रदर्शित होगा। बस सर्वलेट चलाएं और परिणाम देखने के लिए इंतजार करें -
Auto Refresh Header Setting
Current Time is: 9:44:50 PM