Package jakarta.ws.rs.core
Interface EntityPart
- 
 public interface EntityPartAEntityPartis one part of a multipart entity. As defined in RFC 7578, a multipart request or response must have a content type of "multipart/form-data" with aboundaryparameter indicating where one part ends the next may begin.Multipart entities may be received in a resource method as a collection of parts (e.g. List<EntityPart>) or as a form parameter (ex:@FormParam("part1Name") EntityPart part1).Likewise, a client may receive a multipart response by reading the returned entity as a collection of EntityParts (ex: response.readEntity(new GenericType<List<EntityPart>>() {})).In order to send a multipart entity either as a client request or a response from a resource method, you may create the Lists using EntityPart.Builder. For example:Client c = ClientBuilder.newClient(); WebTarget target = c.target(someURL); List<EntityPart> parts = Arrays.asList( EntityPart.withName("name1").fileName("file1.doc").content(stream1).build(), EntityPart.withName("name2").fileName("file2.doc").content(stream2).build(), EntityPart.withName("name3").fileName("file3.xml").content(myObject, MyClass.class).mediaType("application/xml").build()); GenericEntity<List<EntityPart>> genericEntity = new GenericEntity<>(parts){}; Entity entity = Entity.entity(genericEntity, MediaType.MULTIPART_FORM_DATA); Response r = target.request().post(entity);Note that when building a EntityPart, the name and content are required. Other properties such as headers, file name, and media type are optional. It is the responsibility of the implementation code to close the content input streams when sending the multipart content. Closing the stream before the implementation has sent it could result in unexpected exceptions. It is the responsibility of the calling code to close the stream when receiving the multipart content.- Since:
- 3.1
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Interface Description static interfaceEntityPart.BuilderBuilder forEntityPartinstances.
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Modifier and Type Method Description InputStreamgetContent()Returns the input stream for this part.<T> TgetContent(GenericType<T> type)Converts the content stream for this part to the specified type and returns it.<T> TgetContent(Class<T> type)Converts the content stream for this part to the specified class and returns it.Optional<String>getFileName()Returns the filename of this part.MultivaluedMap<String,String>getHeaders()Returns an immutable multivalued map of headers for this specific part.MediaTypegetMediaType()Returns the content type of this part, and equivalent to callingMediaType.valueOf(part.getHeaders().getFirst(HttpHeaders.CONTENT_TYPE)).StringgetName()Returns the name of this part within the multipart entity.static EntityPart.BuilderwithFileName(String partAndFileName)Creates a newEntityPart.Builderinstance that sets the partnameandfileNameto the passed inpartAndFileNamevalue.static EntityPart.BuilderwithName(String partName)Creates a newEntityPart.Builderinstance.
 
- 
- 
- 
Method Detail- 
withNamestatic EntityPart.Builder withName(String partName) Creates a newEntityPart.Builderinstance.- Parameters:
- partName- name of the part to create within the multipart entity
- Returns:
- EntityPart.Builderfor building new- EntityPartinstances
 
 - 
withFileNamestatic EntityPart.Builder withFileName(String partAndFileName) Creates a newEntityPart.Builderinstance that sets the partnameandfileNameto the passed inpartAndFileNamevalue.Logically, this is the same as EntityPart.withName(x).fileName(x).- Parameters:
- partAndFileName- name and filename of the part to create within the multipart entity
- Returns:
- EntityPart.Builderfor building new- EntityPartinstances
 
 - 
getNameString getName() Returns the name of this part within the multipart entity. This will be the "name" attribute of theContent-Dispositionheader for this part.- Returns:
- the part name
 
 - 
getFileNameOptional<String> getFileName() Returns the filename of this part. This will be the "filename" attribute of theContent-Dispositionheader for this part. A filename is not required in a part, so if a filename is not present it will returnOptional.empty().- Returns:
- an Optional<String>indicating the filename if present
 
 - 
getContentInputStream getContent() Returns the input stream for this part. This is the content body of the part and is accessed as a stream to avoid loading potentially large amounts of data into the heap. It is the responsibility of the calling code to close this stream after receiving it.- Returns:
- an InputStreamrepresenting the content of this part
 
 - 
getContent<T> T getContent(Class<T> type) throws IllegalArgumentException, IllegalStateException, IOException, WebApplicationException Converts the content stream for this part to the specified class and returns it. The implementation must convert the stream by finding aMessageBodyReaderthat handles the specified type as well as theMediaTypeof the part. If noMessageBodyReadercan be found to perform the conversion, this method will throw anIllegalArgumentException. The implementation is required to close the content stream when this method is invoked, so it may only be invoked once. Subsequent invocations will result in anIllegalStateException. Likewise this method will throw anIllegalStateExceptionif it is called after callinggetContent()orgetContent(GenericType).- Type Parameters:
- T- the entity type
- Parameters:
- type- the- Classthat the implementation should convert this part to
- Returns:
- an instance of the specified Classrepresenting the content of this part
- Throws:
- IllegalArgumentException- if no- MessageBodyReadercan handle the conversion of this part to the specified type
- IllegalStateException- if this method or any of the other- getContentmethods has already been invoked
- IOException- if the- MessageBodyReader.readFrom(Class, java.lang.reflect.Type, java.lang.annotation.Annotation[], MediaType, MultivaluedMap, InputStream)method throws an- IOException
- WebApplicationException- if the- MessageBodyReader.readFrom(Class, java.lang.reflect.Type, java.lang.annotation.Annotation[], MediaType, MultivaluedMap, InputStream)method throws an- WebApplicationException
 
 - 
getContent<T> T getContent(GenericType<T> type) throws IllegalArgumentException, IllegalStateException, IOException, WebApplicationException Converts the content stream for this part to the specified type and returns it. The implementation must convert the stream by finding aMessageBodyReaderthat handles the specified type as well as theMediaTypeof the part. If noMessageBodyReadercan be found to perform the conversion, this method will throw anIllegalArgumentException. The implementation is required to close the content stream when this method is invoked, so it may only be invoked once. Subsequent invocations will result in anIllegalStateException. Likewise this method will throw anIllegalStateExceptionif it is called after callinggetContent()orgetContent(Class).- Type Parameters:
- T- the entity type
- Parameters:
- type- the generic type that the implementation should convert this part to
- Returns:
- an instance of the specified generic type representing the content of this part
- Throws:
- IllegalArgumentException- if no- MessageBodyReadercan handle the conversion of this part to the specified type
- IllegalStateException- if this method or any of the other- getContentmethods has already been invoked
- IOException- if the- MessageBodyReader.readFrom(Class, java.lang.reflect.Type, java.lang.annotation.Annotation[], MediaType, MultivaluedMap, InputStream)method throws an- IOException
- WebApplicationException- if the- MessageBodyReader.readFrom(Class, java.lang.reflect.Type, java.lang.annotation.Annotation[], MediaType, MultivaluedMap, InputStream)method throws an- WebApplicationException
 
 - 
getHeadersMultivaluedMap<String,String> getHeaders() Returns an immutable multivalued map of headers for this specific part.- Returns:
- immutable MultivaluedMap<String, String>of part headers
 
 - 
getMediaTypeMediaType getMediaType() Returns the content type of this part, and equivalent to callingMediaType.valueOf(part.getHeaders().getFirst(HttpHeaders.CONTENT_TYPE)).- Returns:
- the media type for this part
 
 
- 
 
-