//
// ========================================================================
// 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:
/** * 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:
/** * 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; } }