HTML Tutorials |
|
XML Tutorials |
|
Browser Scripting |
|
Server Scripting |
|
.NET (dotnet) |
|
Multimedia |
|
Web Building |
|
Java Tutorials |
|
Programming Langauges |
|
Soft Skills |
|
Database Tutorials |
|
Operating System |
|
Software Testing |
|
SAP Module |
|
Networking Programming |
|
Microsoft Office |
|
Accounting |
|
|
Generazione della risposta dell'assistente: Intestazioni di risposta del HTTP |
Una risposta dal web server consiste normalmente di una linea di condizione, di una o pi� intestazioni di risposta, di una linea in bianco e del documento. La regolazione delle intestazioni di risposta del HTTP va spesso di pari passo con la regolazione i codici status nella linea di condizione. Per esempio, vari dei codici status spostati �documento� hanno un'intestazione accompagnante di posizione e i 401 il codice (non autorizzato) che deve includere accompagnare WWW-Autenticano intestazione.
|
Descrizione
|
Il senso pi� generale specificare le intestazioni � con il metodo del setHeader di HttpServletResponse, che prende due stringhe: il nome dell'intestazione ed il valore dell'intestazione. Come la regolazione dei codici status, questo deve essere fatto prima che tutto il soddisfare del documento sia trasmesso.
Ci sono inoltre due metodi specializzati per regolare le intestazioni che contengono le date (setDateHeader) ed i numeri interi (setIntHeader). Il primo li conserva difficolt� di traduzione della data del Java nei millisecondi dall'epoca (come rinviato con System.currentTimeMillis o il metodo del getTime applicato ad un oggetto della data) in una stringa dell'ora del GMT. Il secondo li risparmia l'inconveniente secondario del convertire un interno in stringa.
Piuttosto che regolando l'intestazione autentica, potete aggiungere una nuova intestazione, nel caso un'intestazione con quel nome gi� esiste. Usare il addHeader, il addDateHeader e il addIntHeader per questo. Se realmente importa a voi se un'intestazione specifica gi� � stata regolata, usare il containsHeader per controllare.
Per concludere, HttpServletResponse inoltre fornisce un certo numero di metodi della convenienza per le intestazioni comuni specificanti.
Il metodo del setContentType regola il Soddisfare-Tipo intestazione ed � usato dalla maggior parte dei servlets.
Il metodo del setContentLength regola l'intestazione di Soddisfare-Lunghezza, utile se il browser sostiene i collegamenti (manten-vivi) persistenti del HTTP.
Il metodo del addCookie regola il biscotto (non ci � setCookie corrispondente, poich� � normale avere linee multiple del Regol-Biscotto).
E, come discusso nella sezione precedente, il metodo del sendRedirect regola l'intestazione di posizione cos� come la regolazione del codice status a 302.
|
Intestazioni comuni di risposta ed il loro significato
|
Header
|
Interpretation/Purpose
|
Allow
|
What request methods (GET, POST, etc.)
does the server support?
|
Content-Encoding
|
What method was used to encode the document? You need to decode it
to get the type specified by the Content-Type header. Using
gzip to compress the document can dramatically reduce download times for
HTML files, but it is only supported by Netscape on Unix and IE 4 and 5
on Windows. On the other hand, gzipping HTML files can dramatically
reduce download times, and Java's GZIPOutputStream makes it
easy. So you should explicitly check if the browser supports this by
looking at the Accept-Encoding header (i.e. via
request.getHeader("Accept-Encoding")). That way, you can return
gzipped pages to browser that know how to unzip them, but still return
regular pages to other browsers.
|
Content-Length
|
How many bytes are being sent? This information is only needed if
the browser is using a persistent (keep-alive) HTTP connection. If you
want your servlet to take advantage of this when the browser supports
it, your servlet should write the document into a
ByteArrayOutputStream, look up its size when done, put that into
the Content-Length field, then send the content via
byteArrayStream.writeTo(response.getOutputStream()).
|
Content-Type
|
What is the MIME type of the following document? Default for
servlets is text/plain, but they usually explicitly specify
text/html. Setting this header is so common that there is a
special method in HttpServletResponse for it:
setContentType
|
Date
|
What is current time (in GMT)? Use the setDateHeader
method to specify this header. That saves you the trouble of formatting
the date string properly.
|
Expires
|
At what time should content be considered out of date and thus no
longer cached?
|
Last-Modified
|
When was document last changed? Client can supply a date via an
If-Modified-Since request header. This is treated as a
conditional GET, with document only being returned if the
Last-Modified date is later than the specified date.
Otherwise a 304 (Not Modified) status line is returned. Again, use the
setDateHeader method to specify this header.
|
Location
|
Where should client go to get document? This is usually set
indirectly, along with a 302 status code, via the sendRedirect
method of HttpServletResponse.
|
Refresh
|
How soon should browser ask for an updated page (in seconds)?
Instead of just reloading current page, you can specify a specific page
to load via setHeader("Refresh", "5; URL=http://host/path").
Note that this is commonly set via <META HTTP-EQUIV="Refresh"
CONTENT="5; URL=http://host/path"> in the HEAD
section of the HTML page, rather than as an explicit header from the
server. This is because automatic reloading or forwarding is something
often desired by HTML authors who do not have CGI or servlet access. But
for servlets, setting the header directly is easier and clearer. Note
that this header means "reload this page or go to the specified URL in
N seconds." It does not mean "reload this page or go to
the specified URL every N seconds." So you have to send a
Refresh header each time, and sending a 204 (No Content)
status code stops the browser from reloading further, regardless of
whether you explicitly send the Refresh header or use
<META HTTP-EQUIV="Refresh" ...>. Note that this header is not
officially part of HTTP 1.1, but is an extension supported by both
Netscape and Internet Explorer.
|
Server
|
What server am I? Servlets don't usually set this; the Web server
itself does.
|
Set-Cookie
|
Specifies cookie associated with page. Servlets should not use
response.setHeader("Set-Cookie", ...), but instead use the
special-purpose addCookie method of
HttpServletResponse. See separate section on handling cookies.
|
WWW-Authenticate
|
What authorization type and realm should client supply in their
Authorization header? This header is required in responses
that have a 401 (Unauthorized) status line. E.g.
response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"").
Note that servlets do not usually handle this themselves, but instead
let password-protected Web pages be handled by the Web server's
specialized mechanisms (e.g. .htaccess). |
|
|
|
Keywords:
Handling the Client Request:Form Data,asp net client,asp net data,vb net data,control data,data net,java client,data repeater
|
|
HTML Quizes |
|
XML Quizes |
|
Browser Scripting Quizes |
|
Server Scripting Quizes |
|
.NET (dotnet) Quizes |
|
Multimedia Quizes |
|
Web Building Quizes |
|
Java Quizes |
|
Programming Langauges Quizes |
|
Soft Skills Quizes |
|
Database Quizes |
|
Operating System Quizes |
|
Software Testing Quizes |
|
SAP Module Quizes |
|
Networking Programming Quizes |
|
Microsoft Office Quizes |
|
Accounting Quizes |
|
|