Package org.eclipse.jetty.server
Class Response
java.lang.Object
org.eclipse.jetty.server.Response
- All Implemented Interfaces:
jakarta.servlet.http.HttpServletResponse,jakarta.servlet.ServletResponse
Response provides the implementation for HttpServletResponse.
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intstatic final StringIf a header name starts with this string, the header (stripped of the prefix) can be set during include using onlysetHeader(String, String)oraddHeader(String, String).static final intFields inherited from interface jakarta.servlet.http.HttpServletResponse
SC_ACCEPTED, SC_BAD_GATEWAY, SC_BAD_REQUEST, SC_CONFLICT, SC_CONTINUE, SC_CREATED, SC_EXPECTATION_FAILED, SC_FORBIDDEN, SC_FOUND, SC_GATEWAY_TIMEOUT, SC_GONE, SC_HTTP_VERSION_NOT_SUPPORTED, SC_INTERNAL_SERVER_ERROR, SC_LENGTH_REQUIRED, SC_METHOD_NOT_ALLOWED, SC_MOVED_PERMANENTLY, SC_MOVED_TEMPORARILY, SC_MULTIPLE_CHOICES, SC_NO_CONTENT, SC_NON_AUTHORITATIVE_INFORMATION, SC_NOT_ACCEPTABLE, SC_NOT_FOUND, SC_NOT_IMPLEMENTED, SC_NOT_MODIFIED, SC_OK, SC_PARTIAL_CONTENT, SC_PAYMENT_REQUIRED, SC_PRECONDITION_FAILED, SC_PROXY_AUTHENTICATION_REQUIRED, SC_REQUEST_ENTITY_TOO_LARGE, SC_REQUEST_TIMEOUT, SC_REQUEST_URI_TOO_LONG, SC_REQUESTED_RANGE_NOT_SATISFIABLE, SC_RESET_CONTENT, SC_SEE_OTHER, SC_SERVICE_UNAVAILABLE, SC_SWITCHING_PROTOCOLS, SC_TEMPORARY_REDIRECT, SC_UNAUTHORIZED, SC_UNSUPPORTED_MEDIA_TYPE, SC_USE_PROXY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddCookie(jakarta.servlet.http.Cookie cookie) voidaddCookie(HttpCookie cookie) voidaddDateHeader(String name, long date) voidvoidaddIntHeader(String name, int value) voidvoidDeprecated.voidcompleteOutput(Callback callback) booleancontainsHeader(String name) encodeRedirectUrl(String url) Deprecated.encodeRedirectURL(String url) Deprecated.voidvoidintGet the MetaData.Response committed for this response.longlonggetHeaders(String name) longjakarta.servlet.ServletOutputStreamintvoidinclude()voidincluded()booleanisAllContentWritten(long written) booleanbooleanisContentComplete(long written) booleanbooleanbooleanbooleanprotected MetaData.Responsestatic voidputHeaders(jakarta.servlet.http.HttpServletResponse response, HttpContent content, long contentLength, boolean etag) voidputHeaders(HttpContent content, long contentLength, boolean etag) protected voidrecycle()voidreopen()voidreplaceCookie(HttpCookie cookie) Replace (or add) a cookie.voidreset()voidvoidvoidvoidSends a 103 Early Hint response.voidsendError(int sc) voidSend an error response.voidSends a 102-Processing response.voidsendRedirect(int code, String location) Sends a response with one of the 300 series redirection codes.voidsendRedirect(int code, String location, boolean consumeAll) Sends a response with a given redirection code.voidsendRedirect(String location) voidsendRedirect(String location, boolean consumeAll) Sends a response with a HTTP version appropriate 30x redirection.voidsetBufferSize(int size) voidsetCharacterEncoding(String encoding) voidsetContentLength(int len) voidsetContentLengthLong(long length) voidsetContentType(String contentType) voidsetDateHeader(String name, long date) voidvoidsetHeader(HttpHeader name, String value) voidsetIntHeader(String name, int value) voidvoidsetLongContentLength(long len) voidsetStatus(int sc) voidDeprecated.voidsetStatusWithReason(int sc, String message) voidsetTrailerFields(Supplier<Map<String, String>> trailers) voidsetTrailers(Supplier<HttpFields> trailers) static StringtoRedirectURI(jakarta.servlet.http.HttpServletRequest request, String location) Common point to generate a proper "Location" header for redirects.toString()static jakarta.servlet.http.HttpServletResponseunwrap(jakarta.servlet.ServletResponse servletResponse)
-
Field Details
-
NO_CONTENT_LENGTH
public static final int NO_CONTENT_LENGTH- See Also:
-
USE_KNOWN_CONTENT_LENGTH
public static final int USE_KNOWN_CONTENT_LENGTH- See Also:
-
SET_INCLUDE_HEADER_PREFIX
If a header name starts with this string, the header (stripped of the prefix) can be set during include using onlysetHeader(String, String)oraddHeader(String, String).- See Also:
-
-
Constructor Details
-
Response
-
-
Method Details
-
getHttpChannel
-
recycle
protected void recycle() -
getHttpOutput
-
reopen
public void reopen() -
errorClose
public void errorClose() -
isIncluding
public boolean isIncluding() -
include
public void include() -
included
public void included() -
addCookie
-
addCookie
public void addCookie(jakarta.servlet.http.Cookie cookie) - Specified by:
addCookiein interfacejakarta.servlet.http.HttpServletResponse
-
replaceCookie
Replace (or add) a cookie. Using name, path and domain, look for a matching set-cookie header and replace it.- Parameters:
cookie- The cookie to add/replace
-
containsHeader
- Specified by:
containsHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
encodeURL
- Specified by:
encodeURLin interfacejakarta.servlet.http.HttpServletResponse
-
encodeRedirectURL
- Specified by:
encodeRedirectURLin interfacejakarta.servlet.http.HttpServletResponse
-
encodeUrl
Deprecated.- Specified by:
encodeUrlin interfacejakarta.servlet.http.HttpServletResponse
-
encodeRedirectUrl
Deprecated.- Specified by:
encodeRedirectUrlin interfacejakarta.servlet.http.HttpServletResponse
-
sendError
- Specified by:
sendErrorin interfacejakarta.servlet.http.HttpServletResponse- Throws:
IOException
-
sendError
Send an error response.In addition to the servlet standard handling, this method supports some additional codes:
- 102
- Send a partial PROCESSING response and allow additional responses
- 103
- Send a partial EARLY_HINT response as per RFC8297
- -1
- Abort the HttpChannel and close the connection/stream
- Specified by:
sendErrorin interfacejakarta.servlet.http.HttpServletResponse- Parameters:
code- The error codemessage- The message- Throws:
IOException- If an IO problem occurred sending the error response.
-
sendProcessing
Sends a 102-Processing response. If the request had an Expect header starting with 102, then a 102 response is sent. This indicates that the request still be processed and real response can still be sent. This method is called by sendError if it is passed 102.- Throws:
IOException- if unable to send the 102 response- See Also:
-
HttpServletResponse.sendError(int)
-
sendEarlyHint
Sends a 103 Early Hint response. Send a 103 response as per RFC8297 This method is called by sendError if it is passed 103.- Throws:
IOException- if unable to send the 103 response- See Also:
-
HttpServletResponse.sendError(int)
-
sendRedirect
Sends a response with one of the 300 series redirection codes.- Parameters:
code- the redirect status codelocation- the location to send inLocationheaders- Throws:
IOException- if unable to send the redirect
-
sendRedirect
Sends a response with a HTTP version appropriate 30x redirection.- Parameters:
location- the location to send inLocationheadersconsumeAll- if True, consume any HTTP/1 request input before doing the redirection. If the input cannot be consumed without blocking, then add a `Connection: close` header to the response.- Throws:
IOException- if unable to send the redirect
-
sendRedirect
Sends a response with a given redirection code.- Parameters:
code- the redirect status codelocation- the location to send inLocationheadersconsumeAll- if True, consume any HTTP/1 request input before doing the redirection. If the input cannot be consumed without blocking, then add a `Connection: close` header to the response.- Throws:
IOException- if unable to send the redirect
-
sendRedirect
- Specified by:
sendRedirectin interfacejakarta.servlet.http.HttpServletResponse- Throws:
IOException
-
toRedirectURI
public static String toRedirectURI(jakarta.servlet.http.HttpServletRequest request, String location) Common point to generate a proper "Location" header for redirects.- Parameters:
request- the request the redirect should be based on (needed when relative locations are provided, so that server name, scheme, port can be built out properly)location- the location as an absolute URI or an encoded relative path. A relative path starting with '/' is relative to the root, otherwise it is relative to the request path.- Returns:
- the full redirect "Location" URL (including scheme, host, port, path, etc...)
-
setDateHeader
- Specified by:
setDateHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
addDateHeader
- Specified by:
addDateHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
setHeader
-
setHeader
- Specified by:
setHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
getHeaderNames
- Specified by:
getHeaderNamesin interfacejakarta.servlet.http.HttpServletResponse
-
getHeader
- Specified by:
getHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
getHeaders
- Specified by:
getHeadersin interfacejakarta.servlet.http.HttpServletResponse
-
addHeader
- Specified by:
addHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
setIntHeader
- Specified by:
setIntHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
addIntHeader
- Specified by:
addIntHeaderin interfacejakarta.servlet.http.HttpServletResponse
-
setStatus
public void setStatus(int sc) - Specified by:
setStatusin interfacejakarta.servlet.http.HttpServletResponse
-
setStatus
Deprecated.- Specified by:
setStatusin interfacejakarta.servlet.http.HttpServletResponse
-
setStatusWithReason
-
getCharacterEncoding
- Specified by:
getCharacterEncodingin interfacejakarta.servlet.ServletResponse
-
getContentType
- Specified by:
getContentTypein interfacejakarta.servlet.ServletResponse
-
getOutputStream
- Specified by:
getOutputStreamin interfacejakarta.servlet.ServletResponse- Throws:
IOException
-
isWriting
public boolean isWriting() -
isStreaming
public boolean isStreaming() -
isWritingOrStreaming
public boolean isWritingOrStreaming() -
getWriter
- Specified by:
getWriterin interfacejakarta.servlet.ServletResponse- Throws:
IOException
-
setContentLength
public void setContentLength(int len) - Specified by:
setContentLengthin interfacejakarta.servlet.ServletResponse
-
getContentLength
public long getContentLength() -
isAllContentWritten
public boolean isAllContentWritten(long written) -
isContentComplete
public boolean isContentComplete(long written) -
closeOutput
- Throws:
IOException
-
completeOutput
Deprecated.UsecloseOutput()close the output- Throws:
IOException
-
completeOutput
-
getLongContentLength
public long getLongContentLength() -
setLongContentLength
public void setLongContentLength(long len) -
setContentLengthLong
public void setContentLengthLong(long length) - Specified by:
setContentLengthLongin interfacejakarta.servlet.ServletResponse
-
setCharacterEncoding
- Specified by:
setCharacterEncodingin interfacejakarta.servlet.ServletResponse
-
setContentType
- Specified by:
setContentTypein interfacejakarta.servlet.ServletResponse
-
setBufferSize
public void setBufferSize(int size) - Specified by:
setBufferSizein interfacejakarta.servlet.ServletResponse
-
getBufferSize
public int getBufferSize()- Specified by:
getBufferSizein interfacejakarta.servlet.ServletResponse
-
flushBuffer
- Specified by:
flushBufferin interfacejakarta.servlet.ServletResponse- Throws:
IOException
-
reset
public void reset()- Specified by:
resetin interfacejakarta.servlet.ServletResponse
-
resetContent
public void resetContent() -
resetForForward
public void resetForForward() -
resetBuffer
public void resetBuffer()- Specified by:
resetBufferin interfacejakarta.servlet.ServletResponse
-
getTrailers
-
setTrailers
-
getTrailerFields
- Specified by:
getTrailerFieldsin interfacejakarta.servlet.http.HttpServletResponse
-
setTrailerFields
- Specified by:
setTrailerFieldsin interfacejakarta.servlet.http.HttpServletResponse
-
newResponseMetaData
-
getCommittedMetaData
Get the MetaData.Response committed for this response. This may differ from the meta data in this response for exceptional responses (eg 4xx and 5xx responses generated by the container) and the committedMetaData should be used for logging purposes.- Returns:
- The committed MetaData or a
newResponseMetaData()if not yet committed.
-
isCommitted
public boolean isCommitted()- Specified by:
isCommittedin interfacejakarta.servlet.ServletResponse
-
setLocale
- Specified by:
setLocalein interfacejakarta.servlet.ServletResponse
-
getLocale
- Specified by:
getLocalein interfacejakarta.servlet.ServletResponse
-
getStatus
public int getStatus()- Specified by:
getStatusin interfacejakarta.servlet.http.HttpServletResponse
-
getReason
-
getHttpFields
-
getContentCount
public long getContentCount() -
toString
-
putHeaders
-
putHeaders
public static void putHeaders(jakarta.servlet.http.HttpServletResponse response, HttpContent content, long contentLength, boolean etag) -
unwrap
public static jakarta.servlet.http.HttpServletResponse unwrap(jakarta.servlet.ServletResponse servletResponse)
-
closeOutput()