org.simpleframework.http.message.BufferPart Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of simple Show documentation
Show all versions of simple Show documentation
Simple is a high performance asynchronous HTTP server for Java
/*
* BufferPart.java February 2012
*
* Copyright (C) 2007, Niall Gallagher
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package org.simpleframework.http.message;
import java.io.IOException;
import java.io.InputStream;
import org.simpleframework.http.ContentDisposition;
import org.simpleframework.http.ContentType;
import org.simpleframework.http.Part;
import org.simpleframework.util.buffer.Buffer;
/**
* The BufferPart
is used to represent a part within
* a request message. Typically a part represents either a text
* parameter or a file, with associated headers. The contents of
* the part can be acquire as an InputStream
or as a
* string encoded in the default HTTP encoding ISO-8859-1 or in
* the encoding specified with the Content-Type header.
*
* @author Niall Gallagher
*/
class BufferPart implements Part {
/**
* This is the segment representing the headers for the part.
*/
private final Segment segment;
/**
* This is the body that forms the payload for the part.
*/
private final Body body;
/**
* Constructor for the BufferPart
object. This is
* used to create a part from a multipart body. Each part will
* contain the headers associated with it as well as the body.
*
* @param segment this holds the headers for the part
* @param buffer this represents the body for the part
*/
public BufferPart(Segment segment, Buffer buffer) {
this.body = new BufferBody(buffer);
this.segment = segment;
}
/**
* This method is used to determine the type of a part. Typically
* a part is either a text parameter or a file. If this is true
* then the content represented by the associated part is a file.
*
* @return this returns true if the associated part is a file
*/
public boolean isFile() {
return getDisposition().isFile();
}
/**
* This method is used to acquire the name of the part. Typically
* this is used when the part represents a text parameter rather
* than a file. However, this can also be used with a file part.
*
* @return this returns the name of the associated part
*/
public String getName() {
return getDisposition().getName();
}
/**
* This method is used to acquire the file name of the part. This
* is used when the part represents a text parameter rather than
* a file. However, this can also be used with a file part.
*
* @return this returns the file name of the associated part
*/
public String getFileName() {
return getDisposition().getFileName();
}
/**
* This is used to acquire the content of the part as a string.
* The encoding of the string is taken from the content type.
* If no content type is sent the content is decoded in the
* standard default of ISO-8859-1.
*
* @return this returns a string representing the content
*
* @throws IOException thrown if the content can not be created
*/
public String getContent() throws IOException {
return body.getContent();
}
/**
* This is used to acquire an InputStream
for the
* part. Acquiring the stream allows the content of the part to
* be consumed by reading the stream. Each invocation of this
* method will produce a new stream starting from the first byte.
*
* @return this returns the stream for this part object
*
* @throws IOException thrown if the stream can not be created
*/
public InputStream getInputStream() throws IOException {
return body.getInputStream();
}
/**
* This is used to acquire the content type for this part. This
* is typically the type of content for a file part, as provided
* by a MIME type from the HTTP "Content-Type" header.
*
* @return this returns the content type for the part object
*/
public ContentType getContentType() {
return segment.getContentType();
}
/**
* This is used to acquire the content disposition for the part.
* The content disposition contains the Content-Disposition header
* details sent with the part in the multipart request body.
*
* @return value of the header mapped to the specified name
*/
public ContentDisposition getDisposition() {
return segment.getDisposition();
}
/**
* This is used to acquire the header value for the specified
* header name. Providing the header values through this method
* ensures any special processing for a know content type can be
* handled by an application.
*
* @param name the name of the header to get the value for
*
* @return value of the header mapped to the specified name
*/
public String getHeader(String name) {
return segment.getValue(name);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy