Class SseEmitter
- java.lang.Object
- org.springframework.web.servlet.mvc.method.annotation.ResponseBodyEmitter
- org.springframework.web.servlet.mvc.method.annotation.SseEmitter
public class SseEmitter extends ResponseBodyEmitter
A specialization ofResponseBodyEmitterfor sending Server-Sent Events.- Since:
- 4.2
- Author:
- Rossen Stoyanchev, Juergen Hoeller
Nested Class Summary
Nested Classes Modifier and Type Class Description static interfaceSseEmitter.SseEventBuilderA builder for an SSE event.Nested classes/interfaces inherited from class org.springframework.web.servlet.mvc.method.annotation.ResponseBodyEmitter
ResponseBodyEmitter.DataWithMediaType
Constructor Summary
Constructors Constructor Description SseEmitter()Create a new SseEmitter instance.SseEmitter(Long timeout)Create a SseEmitter with a custom timeout value.
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static SseEmitter.SseEventBuilderevent()protected voidextendResponse(ServerHttpResponse outputMessage)Invoked after the response is updated with the status code and headers, if the ResponseBodyEmitter is wrapped in a ResponseEntity, but before the response is committed, i.e.voidsend(Object object)Send the object formatted as a single SSE "data" line.voidsend(Object object, MediaType mediaType)Send the object formatted as a single SSE "data" line.voidsend(SseEmitter.SseEventBuilder builder)Send an SSE event prepared with the given builder.StringtoString()Methods inherited from class org.springframework.web.servlet.mvc.method.annotation.ResponseBodyEmitter
complete, completeWithError, getTimeout, onCompletion, onTimeout
Constructor Detail
SseEmitter
public SseEmitter()
Create a new SseEmitter instance.
SseEmitter
public SseEmitter(Long timeout)
Create a SseEmitter with a custom timeout value.By default not set in which case the default configured in the MVC Java Config or the MVC namespace is used, or if that's not set, then the timeout depends on the default of the underlying server.
- Parameters:
timeout- timeout value in milliseconds- Since:
- 4.2.2
Method Detail
extendResponse
protected void extendResponse(ServerHttpResponse outputMessage)
Description copied from class:ResponseBodyEmitterInvoked after the response is updated with the status code and headers, if the ResponseBodyEmitter is wrapped in a ResponseEntity, but before the response is committed, i.e. before the response body has been written to.The default implementation is empty.
- Overrides:
extendResponsein classResponseBodyEmitter
send
public void send(Object object) throws IOException
Send the object formatted as a single SSE "data" line. It's equivalent to:// static import of SseEmitter.* SseEmitter emitter = new SseEmitter(); emitter.send(event().data(myObject));
- Overrides:
sendin classResponseBodyEmitter- Parameters:
object- the object to write- Throws:
IOException- raised when an I/O error occursIllegalStateException- wraps any other errors
send
public void send(Object object, MediaType mediaType) throws IOException
Send the object formatted as a single SSE "data" line. It's equivalent to:// static import of SseEmitter.* SseEmitter emitter = new SseEmitter(); emitter.send(event().data(myObject, MediaType.APPLICATION_JSON));
- Overrides:
sendin classResponseBodyEmitter- Parameters:
object- the object to writemediaType- a MediaType hint for selecting an HttpMessageConverter- Throws:
IOException- raised when an I/O error occurs
send
public void send(SseEmitter.SseEventBuilder builder) throws IOException
Send an SSE event prepared with the given builder. For example:// static import of SseEmitter SseEmitter emitter = new SseEmitter(); emitter.send(event().name("update").id("1").data(myObject));- Parameters:
builder- a builder for an SSE formatted event.- Throws:
IOException- raised when an I/O error occurs
event
public static SseEmitter.SseEventBuilder event()