//
// ========================================================================
// Copyright (c) 1995-2020 Mort Bay Consulting Pty Ltd and others.
//
// This program and the accompanying materials are made available under
// the terms of the Eclipse Public License 2.0 which is available at
// https://www.eclipse.org/legal/epl-2.0
//
// This Source Code may also be made available under the following
// Secondary Licenses when the conditions for such availability set
// forth in the Eclipse Public License, v. 2.0 are satisfied:
// the Apache License v2.0 which is available at
// https://www.apache.org/licenses/LICENSE-2.0
//
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
// ========================================================================
//
package org.eclipse.jetty.util;
import java.io.FilterWriter;
import java.io.IOException;
import java.io.Writer;
Handle a multipart MIME response.
/**
* Handle a multipart MIME response.
*/
public class MultiPartWriter extends FilterWriter
{
private static final String __CRLF = "\r\n";
private static final String __DASHDASH = "--";
public static final String MULTIPART_MIXED = MultiPartOutputStream.MULTIPART_MIXED;
public static final String MULTIPART_X_MIXED_REPLACE = MultiPartOutputStream.MULTIPART_X_MIXED_REPLACE;
private String boundary;
private boolean inPart = false;
public MultiPartWriter(Writer out)
throws IOException
{
super(out);
boundary = "jetty" + System.identityHashCode(this) +
Long.toString(System.currentTimeMillis(), 36);
inPart = false;
}
End the current part.
Throws: - IOException – IOException
/**
* End the current part.
*
* @throws IOException IOException
*/
@Override
public void close()
throws IOException
{
try
{
if (inPart)
out.write(__CRLF);
out.write(__DASHDASH);
out.write(boundary);
out.write(__DASHDASH);
out.write(__CRLF);
inPart = false;
}
finally
{
super.close();
}
}
public String getBoundary()
{
return boundary;
}
Start creation of the next Content.
Params: - contentType – the content type
Throws: - IOException – if unable to write the part
/**
* Start creation of the next Content.
*
* @param contentType the content type
* @throws IOException if unable to write the part
*/
public void startPart(String contentType)
throws IOException
{
if (inPart)
out.write(__CRLF);
out.write(__DASHDASH);
out.write(boundary);
out.write(__CRLF);
out.write("Content-Type: ");
out.write(contentType);
out.write(__CRLF);
out.write(__CRLF);
inPart = true;
}
Start creation of the next Content.
Params: - contentType – the content type of the part
- headers – the part headers
Throws: - IOException – if unable to write the part
/**
* Start creation of the next Content.
*
* @param contentType the content type of the part
* @param headers the part headers
* @throws IOException if unable to write the part
*/
public void startPart(String contentType, String[] headers)
throws IOException
{
if (inPart)
out.write(__CRLF);
out.write(__DASHDASH);
out.write(boundary);
out.write(__CRLF);
out.write("Content-Type: ");
out.write(contentType);
out.write(__CRLF);
for (int i = 0; headers != null && i < headers.length; i++)
{
out.write(headers[i]);
out.write(__CRLF);
}
out.write(__CRLF);
inPart = true;
}
end creation of the next Content.
Throws: - IOException – if unable to write the part
/**
* end creation of the next Content.
*
* @throws IOException if unable to write the part
*/
public void endPart()
throws IOException
{
if (inPart)
out.write(__CRLF);
inPart = false;
}
}