Upgraded mime4j to version 0.6
git-svn-id: https://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk@750894 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8849e82869
commit
9940cb5982
|
@ -32,9 +32,7 @@
|
||||||
package org.apache.http.entity.mime;
|
package org.apache.http.entity.mime;
|
||||||
|
|
||||||
import org.apache.http.entity.mime.content.ContentBody;
|
import org.apache.http.entity.mime.content.ContentBody;
|
||||||
import org.apache.james.mime4j.MimeException;
|
|
||||||
import org.apache.james.mime4j.descriptor.ContentDescriptor;
|
import org.apache.james.mime4j.descriptor.ContentDescriptor;
|
||||||
import org.apache.james.mime4j.field.Field;
|
|
||||||
import org.apache.james.mime4j.message.BodyPart;
|
import org.apache.james.mime4j.message.BodyPart;
|
||||||
import org.apache.james.mime4j.message.Header;
|
import org.apache.james.mime4j.message.Header;
|
||||||
|
|
||||||
|
@ -75,8 +73,7 @@ public class FormBodyPart extends BodyPart {
|
||||||
|
|
||||||
protected void generateContentDisp(final ContentBody body) {
|
protected void generateContentDisp(final ContentBody body) {
|
||||||
StringBuilder buffer = new StringBuilder();
|
StringBuilder buffer = new StringBuilder();
|
||||||
buffer.append(MIME.CONTENT_DISPOSITION);
|
buffer.append("form-data; name=\"");
|
||||||
buffer.append(": form-data; name=\"");
|
|
||||||
buffer.append(getName());
|
buffer.append(getName());
|
||||||
buffer.append("\"");
|
buffer.append("\"");
|
||||||
if (body.getFilename() != null) {
|
if (body.getFilename() != null) {
|
||||||
|
@ -84,40 +81,29 @@ public class FormBodyPart extends BodyPart {
|
||||||
buffer.append(body.getFilename());
|
buffer.append(body.getFilename());
|
||||||
buffer.append("\"");
|
buffer.append("\"");
|
||||||
}
|
}
|
||||||
addField(buffer.toString());
|
addField(MIME.CONTENT_DISPOSITION, buffer.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void generateContentType(final ContentDescriptor desc) {
|
protected void generateContentType(final ContentDescriptor desc) {
|
||||||
if (desc.getMimeType() != null) {
|
if (desc.getMimeType() != null) {
|
||||||
StringBuilder buffer = new StringBuilder();
|
StringBuilder buffer = new StringBuilder();
|
||||||
buffer.append(MIME.CONTENT_TYPE);
|
|
||||||
buffer.append(": ");
|
|
||||||
buffer.append(desc.getMimeType());
|
buffer.append(desc.getMimeType());
|
||||||
if (desc.getCharset() != null) {
|
if (desc.getCharset() != null) {
|
||||||
buffer.append("; charset=");
|
buffer.append("; charset=");
|
||||||
buffer.append(desc.getCharset());
|
buffer.append(desc.getCharset());
|
||||||
}
|
}
|
||||||
addField(buffer.toString());
|
addField(MIME.CONTENT_TYPE, buffer.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void generateTransferEncoding(final ContentDescriptor desc) {
|
protected void generateTransferEncoding(final ContentDescriptor desc) {
|
||||||
if (desc.getTransferEncoding() != null) {
|
if (desc.getTransferEncoding() != null) {
|
||||||
StringBuilder buffer = new StringBuilder();
|
addField(MIME.CONTENT_TRANSFER_ENC, desc.getTransferEncoding());
|
||||||
buffer.append(MIME.CONTENT_TRANSFER_ENC);
|
|
||||||
buffer.append(": ");
|
|
||||||
buffer.append(desc.getTransferEncoding());
|
|
||||||
addField(buffer.toString());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addField(final String s) {
|
private void addField(final String name, final String value) {
|
||||||
try {
|
getHeader().addField(new MinimalField(name, value));
|
||||||
getHeader().addField(Field.parse(s));
|
|
||||||
} catch (MimeException ex) {
|
|
||||||
// Should never happen
|
|
||||||
throw new UnexpectedMimeException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,25 +31,28 @@
|
||||||
|
|
||||||
package org.apache.http.entity.mime;
|
package org.apache.http.entity.mime;
|
||||||
|
|
||||||
import java.io.BufferedWriter;
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.OutputStreamWriter;
|
import java.nio.ByteBuffer;
|
||||||
|
import java.nio.CharBuffer;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.http.entity.mime.content.ContentBody;
|
import org.apache.http.entity.mime.content.ContentBody;
|
||||||
import org.apache.http.protocol.HTTP;
|
import org.apache.http.protocol.HTTP;
|
||||||
import org.apache.james.mime4j.MimeException;
|
|
||||||
import org.apache.james.mime4j.field.ContentTypeField;
|
import org.apache.james.mime4j.field.ContentTypeField;
|
||||||
import org.apache.james.mime4j.field.Field;
|
import org.apache.james.mime4j.field.FieldName;
|
||||||
import org.apache.james.mime4j.message.Body;
|
import org.apache.james.mime4j.message.Body;
|
||||||
import org.apache.james.mime4j.message.BodyPart;
|
import org.apache.james.mime4j.message.BodyPart;
|
||||||
import org.apache.james.mime4j.message.Entity;
|
import org.apache.james.mime4j.message.Entity;
|
||||||
|
import org.apache.james.mime4j.message.Header;
|
||||||
|
import org.apache.james.mime4j.message.MessageWriter;
|
||||||
import org.apache.james.mime4j.message.Multipart;
|
import org.apache.james.mime4j.message.Multipart;
|
||||||
|
import org.apache.james.mime4j.parser.Field;
|
||||||
|
import org.apache.james.mime4j.util.ByteArrayBuffer;
|
||||||
|
import org.apache.james.mime4j.util.ByteSequence;
|
||||||
import org.apache.james.mime4j.util.CharsetUtil;
|
import org.apache.james.mime4j.util.CharsetUtil;
|
||||||
import org.apache.james.mime4j.util.MessageUtils;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An extension of the mime4j standard {@link Multipart} class, which is
|
* An extension of the mime4j standard {@link Multipart} class, which is
|
||||||
|
@ -61,6 +64,28 @@ import org.apache.james.mime4j.util.MessageUtils;
|
||||||
*/
|
*/
|
||||||
public class HttpMultipart extends Multipart {
|
public class HttpMultipart extends Multipart {
|
||||||
|
|
||||||
|
private static ByteArrayBuffer encode(Charset charset, String string) {
|
||||||
|
ByteBuffer encoded = charset.encode(CharBuffer.wrap(string));
|
||||||
|
ByteArrayBuffer bab = new ByteArrayBuffer(encoded.remaining());
|
||||||
|
bab.append(encoded.array(), encoded.position(), encoded.remaining());
|
||||||
|
return bab;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void writeBytes(ByteArrayBuffer b, OutputStream out) throws IOException {
|
||||||
|
out.write(b.buffer(), 0, b.length());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void writeBytes(ByteSequence b, OutputStream out) throws IOException {
|
||||||
|
if (b instanceof ByteArrayBuffer) {
|
||||||
|
writeBytes((ByteArrayBuffer) b, out);
|
||||||
|
} else {
|
||||||
|
out.write(b.toByteArray());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final ByteArrayBuffer CR_LF = encode(MIME.DEFAULT_CHARSET, "\r\n");
|
||||||
|
private static final ByteArrayBuffer TWO_DASHES = encode(MIME.DEFAULT_CHARSET, "--");
|
||||||
|
|
||||||
private HttpMultipartMode mode;
|
private HttpMultipartMode mode;
|
||||||
|
|
||||||
public HttpMultipart(final String subType) {
|
public HttpMultipart(final String subType) {
|
||||||
|
@ -79,7 +104,7 @@ public class HttpMultipart extends Multipart {
|
||||||
protected Charset getCharset() {
|
protected Charset getCharset() {
|
||||||
Entity e = getParent();
|
Entity e = getParent();
|
||||||
ContentTypeField cField = (ContentTypeField) e.getHeader().getField(
|
ContentTypeField cField = (ContentTypeField) e.getHeader().getField(
|
||||||
Field.CONTENT_TYPE);
|
FieldName.CONTENT_TYPE);
|
||||||
Charset charset = null;
|
Charset charset = null;
|
||||||
|
|
||||||
switch (this.mode) {
|
switch (this.mode) {
|
||||||
|
@ -100,7 +125,7 @@ public class HttpMultipart extends Multipart {
|
||||||
protected String getBoundary() {
|
protected String getBoundary() {
|
||||||
Entity e = getParent();
|
Entity e = getParent();
|
||||||
ContentTypeField cField = (ContentTypeField) e.getHeader().getField(
|
ContentTypeField cField = (ContentTypeField) e.getHeader().getField(
|
||||||
Field.CONTENT_TYPE);
|
FieldName.CONTENT_TYPE);
|
||||||
return cField.getBoundary();
|
return cField.getBoundary();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,44 +134,49 @@ public class HttpMultipart extends Multipart {
|
||||||
final OutputStream out,
|
final OutputStream out,
|
||||||
boolean writeContent) throws IOException {
|
boolean writeContent) throws IOException {
|
||||||
|
|
||||||
List<?> bodyParts = getBodyParts();
|
List<BodyPart> bodyParts = getBodyParts();
|
||||||
Charset charset = getCharset();
|
Charset charset = getCharset();
|
||||||
String boundary = getBoundary();
|
|
||||||
|
|
||||||
BufferedWriter writer = new BufferedWriter(
|
ByteArrayBuffer boundary = encode(charset, getBoundary());
|
||||||
new OutputStreamWriter(out, charset),
|
|
||||||
8192);
|
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case STRICT:
|
case STRICT:
|
||||||
String preamble = getPreamble();
|
String preamble = getPreamble();
|
||||||
if (preamble != null && preamble.length() != 0) {
|
if (preamble != null && preamble.length() != 0) {
|
||||||
writer.write(preamble);
|
ByteArrayBuffer b = encode(charset, preamble);
|
||||||
writer.write("\r\n");
|
writeBytes(b, out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < bodyParts.size(); i++) {
|
for (int i = 0; i < bodyParts.size(); i++) {
|
||||||
writer.write("--");
|
writeBytes(TWO_DASHES, out);
|
||||||
writer.write(boundary);
|
writeBytes(boundary, out);
|
||||||
writer.write("\r\n");
|
writeBytes(CR_LF, out);
|
||||||
writer.flush();
|
|
||||||
BodyPart part = (BodyPart) bodyParts.get(i);
|
|
||||||
part.getHeader().writeTo(out, MessageUtils.STRICT_IGNORE);
|
|
||||||
if (writeContent) {
|
|
||||||
part.getBody().writeTo(out, MessageUtils.STRICT_IGNORE);
|
|
||||||
}
|
|
||||||
writer.write("\r\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
writer.write("--");
|
BodyPart part = bodyParts.get(i);
|
||||||
writer.write(boundary);
|
Header header = part.getHeader();
|
||||||
writer.write("--\r\n");
|
|
||||||
|
List<Field> fields = header.getFields();
|
||||||
|
for (Field field: fields) {
|
||||||
|
writeBytes(field.getRaw(), out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
|
}
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
|
if (writeContent) {
|
||||||
|
MessageWriter.DEFAULT.writeBody(part.getBody(), out);
|
||||||
|
}
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
|
}
|
||||||
|
writeBytes(TWO_DASHES, out);
|
||||||
|
writeBytes(boundary, out);
|
||||||
|
writeBytes(TWO_DASHES, out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
String epilogue = getEpilogue();
|
String epilogue = getEpilogue();
|
||||||
if (epilogue != null && epilogue.length() != 0) {
|
if (epilogue != null && epilogue.length() != 0) {
|
||||||
writer.write(epilogue);
|
ByteArrayBuffer b = encode(charset, epilogue);
|
||||||
writer.write("\r\n");
|
writeBytes(b, out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
}
|
}
|
||||||
writer.flush();
|
|
||||||
break;
|
break;
|
||||||
case BROWSER_COMPATIBLE:
|
case BROWSER_COMPATIBLE:
|
||||||
|
|
||||||
|
@ -155,28 +185,30 @@ public class HttpMultipart extends Multipart {
|
||||||
// (3) Use content charset
|
// (3) Use content charset
|
||||||
|
|
||||||
for (int i = 0; i < bodyParts.size(); i++) {
|
for (int i = 0; i < bodyParts.size(); i++) {
|
||||||
writer.write("--");
|
writeBytes(TWO_DASHES, out);
|
||||||
writer.write(boundary);
|
writeBytes(boundary, out);
|
||||||
writer.write("\r\n");
|
writeBytes(CR_LF, out);
|
||||||
writer.flush();
|
|
||||||
BodyPart part = (BodyPart) bodyParts.get(i);
|
BodyPart part = (BodyPart) bodyParts.get(i);
|
||||||
|
|
||||||
Field cd = part.getHeader().getField(MIME.CONTENT_DISPOSITION);
|
Field cd = part.getHeader().getField(MIME.CONTENT_DISPOSITION);
|
||||||
writer.write(cd.toString());
|
|
||||||
writer.write("\r\n");
|
|
||||||
writer.write("\r\n");
|
|
||||||
writer.flush();
|
|
||||||
if (writeContent) {
|
|
||||||
part.getBody().writeTo(out, MessageUtils.LENIENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
writer.write("\r\n");
|
StringBuilder s = new StringBuilder();
|
||||||
|
s.append(cd.getName());
|
||||||
|
s.append(": ");
|
||||||
|
s.append(cd.getBody());
|
||||||
|
writeBytes(encode(charset, s.toString()), out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
|
if (writeContent) {
|
||||||
|
MessageWriter.DEFAULT.writeBody(part.getBody(), out);
|
||||||
|
}
|
||||||
|
writeBytes(CR_LF, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
writer.write("--");
|
writeBytes(TWO_DASHES, out);
|
||||||
writer.write(boundary);
|
writeBytes(boundary, out);
|
||||||
writer.write("--\r\n");
|
writeBytes(TWO_DASHES, out);
|
||||||
writer.flush();
|
writeBytes(CR_LF, out);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -192,15 +224,6 @@ public class HttpMultipart extends Multipart {
|
||||||
doWriteTo(this.mode, out, true);
|
doWriteTo(this.mode, out, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void writeTo(final OutputStream out, int mode) throws IOException, MimeException {
|
|
||||||
if (mode == MessageUtils.LENIENT) {
|
|
||||||
doWriteTo(HttpMultipartMode.BROWSER_COMPATIBLE, out, true);
|
|
||||||
} else {
|
|
||||||
doWriteTo(HttpMultipartMode.STRICT, out, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determines the total length of the multipart content (content length of
|
* Determines the total length of the multipart content (content length of
|
||||||
* individual parts plus that of extra elements required to delimit the parts
|
* individual parts plus that of extra elements required to delimit the parts
|
||||||
|
|
|
@ -33,7 +33,7 @@ package org.apache.http.entity.mime;
|
||||||
|
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
|
|
||||||
import org.apache.james.mime4j.field.Field;
|
import org.apache.james.mime4j.field.FieldName;
|
||||||
import org.apache.james.mime4j.util.CharsetUtil;
|
import org.apache.james.mime4j.util.CharsetUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -42,8 +42,8 @@ import org.apache.james.mime4j.util.CharsetUtil;
|
||||||
*/
|
*/
|
||||||
public final class MIME {
|
public final class MIME {
|
||||||
|
|
||||||
public static final String CONTENT_TYPE = Field.CONTENT_TYPE;
|
public static final String CONTENT_TYPE = FieldName.CONTENT_TYPE;
|
||||||
public static final String CONTENT_TRANSFER_ENC = Field.CONTENT_TRANSFER_ENCODING;
|
public static final String CONTENT_TRANSFER_ENC = FieldName.CONTENT_TRANSFER_ENCODING;
|
||||||
public static final String CONTENT_DISPOSITION = "Content-Disposition";
|
public static final String CONTENT_DISPOSITION = "Content-Disposition";
|
||||||
|
|
||||||
public static final String ENC_8BIT = "8bit";
|
public static final String ENC_8BIT = "8bit";
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* $HeadURL:$
|
||||||
|
* $Revision:$
|
||||||
|
* $Date:$
|
||||||
|
*
|
||||||
|
* ====================================================================
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you 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.
|
||||||
|
* ====================================================================
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many
|
||||||
|
* individuals on behalf of the Apache Software Foundation. For more
|
||||||
|
* information on the Apache Software Foundation, please see
|
||||||
|
* <http://www.apache.org/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.http.entity.mime;
|
||||||
|
|
||||||
|
import org.apache.james.mime4j.parser.Field;
|
||||||
|
import org.apache.james.mime4j.util.ByteSequence;
|
||||||
|
import org.apache.james.mime4j.util.ContentUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Minimal implementation of {@link Field}.
|
||||||
|
*
|
||||||
|
* @since 4.0
|
||||||
|
*/
|
||||||
|
public class MinimalField implements Field {
|
||||||
|
|
||||||
|
private final String name;
|
||||||
|
private final String value;
|
||||||
|
|
||||||
|
private ByteSequence raw;
|
||||||
|
|
||||||
|
MinimalField(final String name, final String value) {
|
||||||
|
super();
|
||||||
|
this.name = name;
|
||||||
|
this.value = value;
|
||||||
|
this.raw = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getBody() {
|
||||||
|
return this.value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ByteSequence getRaw() {
|
||||||
|
if (this.raw == null) {
|
||||||
|
this.raw = ContentUtil.encode(toString());
|
||||||
|
}
|
||||||
|
return this.raw;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
StringBuilder buffer = new StringBuilder();
|
||||||
|
buffer.append(this.name);
|
||||||
|
buffer.append(": ");
|
||||||
|
buffer.append(this.value);
|
||||||
|
return buffer.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -44,8 +44,7 @@ import org.apache.http.HttpEntity;
|
||||||
import org.apache.http.entity.mime.content.ContentBody;
|
import org.apache.http.entity.mime.content.ContentBody;
|
||||||
import org.apache.http.message.BasicHeader;
|
import org.apache.http.message.BasicHeader;
|
||||||
import org.apache.http.protocol.HTTP;
|
import org.apache.http.protocol.HTTP;
|
||||||
import org.apache.james.mime4j.MimeException;
|
import org.apache.james.mime4j.field.Fields;
|
||||||
import org.apache.james.mime4j.field.Field;
|
|
||||||
import org.apache.james.mime4j.message.Message;
|
import org.apache.james.mime4j.message.Message;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -91,7 +90,7 @@ public class MultipartEntity implements HttpEntity {
|
||||||
mode = HttpMultipartMode.STRICT;
|
mode = HttpMultipartMode.STRICT;
|
||||||
}
|
}
|
||||||
this.multipart.setMode(mode);
|
this.multipart.setMode(mode);
|
||||||
addField("Content-Type: " + this.contentType.getValue());
|
this.message.getHeader().addField(Fields.contentType(this.contentType.getValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public MultipartEntity(final HttpMultipartMode mode) {
|
public MultipartEntity(final HttpMultipartMode mode) {
|
||||||
|
@ -181,13 +180,4 @@ public class MultipartEntity implements HttpEntity {
|
||||||
this.multipart.writeTo(outstream);
|
this.multipart.writeTo(outstream);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addField(final String s) {
|
|
||||||
try {
|
|
||||||
this.message.getHeader().addField(Field.parse(s));
|
|
||||||
} catch (MimeException ex) {
|
|
||||||
// Should never happen
|
|
||||||
throw new UnexpectedMimeException(ex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,9 +33,11 @@ package org.apache.http.entity.mime;
|
||||||
import org.apache.james.mime4j.MimeException;
|
import org.apache.james.mime4j.MimeException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* @deprecated no longer used.
|
||||||
*
|
*
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public class UnexpectedMimeException extends RuntimeException {
|
public class UnexpectedMimeException extends RuntimeException {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1316818299528463579L;
|
private static final long serialVersionUID = 1316818299528463579L;
|
||||||
|
|
|
@ -34,18 +34,21 @@ package org.apache.http.entity.mime.content;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.james.mime4j.message.AbstractBody;
|
import org.apache.james.mime4j.message.Entity;
|
||||||
|
import org.apache.james.mime4j.message.SingleBody;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractContentBody extends AbstractBody implements ContentBody {
|
public abstract class AbstractContentBody extends SingleBody implements ContentBody {
|
||||||
|
|
||||||
private final String mimeType;
|
private final String mimeType;
|
||||||
private final String mediaType;
|
private final String mediaType;
|
||||||
private final String subType;
|
private final String subType;
|
||||||
|
|
||||||
|
private Entity parent = null;
|
||||||
|
|
||||||
public AbstractContentBody(final String mimeType) {
|
public AbstractContentBody(final String mimeType) {
|
||||||
super();
|
super();
|
||||||
if (mimeType == null) {
|
if (mimeType == null) {
|
||||||
|
@ -61,7 +64,15 @@ public abstract class AbstractContentBody extends AbstractBody implements Conten
|
||||||
this.subType = null;
|
this.subType = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Entity getParent() {
|
||||||
|
return this.parent;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setParent(final Entity parent) {
|
||||||
|
this.parent = parent;
|
||||||
|
}
|
||||||
|
|
||||||
public String getMimeType() {
|
public String getMimeType() {
|
||||||
return this.mimeType;
|
return this.mimeType;
|
||||||
}
|
}
|
||||||
|
@ -74,8 +85,11 @@ public abstract class AbstractContentBody extends AbstractBody implements Conten
|
||||||
return this.subType;
|
return this.subType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<?, ?> getContentTypeParameters() {
|
public Map<String, String> getContentTypeParameters() {
|
||||||
return Collections.EMPTY_MAP;
|
return Collections.emptyMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void dispose() {
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,13 +38,12 @@ import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
import org.apache.http.entity.mime.MIME;
|
import org.apache.http.entity.mime.MIME;
|
||||||
import org.apache.james.mime4j.message.BinaryBody;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
public class FileBody extends AbstractContentBody implements BinaryBody {
|
public class FileBody extends AbstractContentBody {
|
||||||
|
|
||||||
private final File file;
|
private final File file;
|
||||||
|
|
||||||
|
@ -64,7 +63,15 @@ public class FileBody extends AbstractContentBody implements BinaryBody {
|
||||||
return new FileInputStream(this.file);
|
return new FileInputStream(this.file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated use {@link #writeTo(OutputStream)}
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void writeTo(final OutputStream out, int mode) throws IOException {
|
public void writeTo(final OutputStream out, int mode) throws IOException {
|
||||||
|
writeTo(out);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeTo(final OutputStream out) throws IOException {
|
||||||
if (out == null) {
|
if (out == null) {
|
||||||
throw new IllegalArgumentException("Output stream may not be null");
|
throw new IllegalArgumentException("Output stream may not be null");
|
||||||
}
|
}
|
||||||
|
@ -100,5 +107,5 @@ public class FileBody extends AbstractContentBody implements BinaryBody {
|
||||||
public File getFile() {
|
public File getFile() {
|
||||||
return this.file;
|
return this.file;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,13 +36,12 @@ import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
import org.apache.http.entity.mime.MIME;
|
import org.apache.http.entity.mime.MIME;
|
||||||
import org.apache.james.mime4j.message.BinaryBody;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
public class InputStreamBody extends AbstractContentBody implements BinaryBody {
|
public class InputStreamBody extends AbstractContentBody {
|
||||||
|
|
||||||
private final InputStream in;
|
private final InputStream in;
|
||||||
private final String filename;
|
private final String filename;
|
||||||
|
@ -64,7 +63,15 @@ public class InputStreamBody extends AbstractContentBody implements BinaryBody {
|
||||||
return this.in;
|
return this.in;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated use {@link #writeTo(OutputStream)}
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void writeTo(final OutputStream out, int mode) throws IOException {
|
public void writeTo(final OutputStream out, int mode) throws IOException {
|
||||||
|
writeTo(out);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeTo(final OutputStream out) throws IOException {
|
||||||
if (out == null) {
|
if (out == null) {
|
||||||
throw new IllegalArgumentException("Output stream may not be null");
|
throw new IllegalArgumentException("Output stream may not be null");
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,13 +43,12 @@ import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.http.entity.mime.MIME;
|
import org.apache.http.entity.mime.MIME;
|
||||||
import org.apache.james.mime4j.message.TextBody;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @since 4.0
|
* @since 4.0
|
||||||
*/
|
*/
|
||||||
public class StringBody extends AbstractContentBody implements TextBody {
|
public class StringBody extends AbstractContentBody {
|
||||||
|
|
||||||
private final byte[] content;
|
private final byte[] content;
|
||||||
private final Charset charset;
|
private final Charset charset;
|
||||||
|
@ -83,7 +82,15 @@ public class StringBody extends AbstractContentBody implements TextBody {
|
||||||
this.charset);
|
this.charset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated use {@link #writeTo(OutputStream)}
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
public void writeTo(final OutputStream out, int mode) throws IOException {
|
public void writeTo(final OutputStream out, int mode) throws IOException {
|
||||||
|
writeTo(out);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeTo(final OutputStream out) throws IOException {
|
||||||
if (out == null) {
|
if (out == null) {
|
||||||
throw new IllegalArgumentException("Output stream may not be null");
|
throw new IllegalArgumentException("Output stream may not be null");
|
||||||
}
|
}
|
||||||
|
@ -105,8 +112,8 @@ public class StringBody extends AbstractContentBody implements TextBody {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Map<?, ?> getContentTypeParameters() {
|
public Map<String, String> getContentTypeParameters() {
|
||||||
Map<Object, Object> map = new HashMap<Object, Object>();
|
Map<String, String> map = new HashMap<String, String>();
|
||||||
map.put("charset", this.charset.name());
|
map.put("charset", this.charset.name());
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,7 +48,7 @@ import org.apache.http.entity.mime.HttpMultipartMode;
|
||||||
import org.apache.http.entity.mime.content.FileBody;
|
import org.apache.http.entity.mime.content.FileBody;
|
||||||
import org.apache.http.entity.mime.content.InputStreamBody;
|
import org.apache.http.entity.mime.content.InputStreamBody;
|
||||||
import org.apache.http.entity.mime.content.StringBody;
|
import org.apache.http.entity.mime.content.StringBody;
|
||||||
import org.apache.james.mime4j.field.Field;
|
import org.apache.james.mime4j.field.Fields;
|
||||||
import org.apache.james.mime4j.message.BodyPart;
|
import org.apache.james.mime4j.message.BodyPart;
|
||||||
import org.apache.james.mime4j.message.Header;
|
import org.apache.james.mime4j.message.Header;
|
||||||
import org.apache.james.mime4j.message.Message;
|
import org.apache.james.mime4j.message.Message;
|
||||||
|
@ -75,25 +75,24 @@ public class TestMultipartForm extends TestCase {
|
||||||
public void testMultipartFormLowLevel() throws Exception {
|
public void testMultipartFormLowLevel() throws Exception {
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
HttpMultipart multipart = new HttpMultipart("form-data");
|
HttpMultipart multipart = new HttpMultipart("form-data");
|
||||||
multipart.setParent(message);
|
multipart.setParent(message);
|
||||||
BodyPart p1 = new BodyPart();
|
BodyPart p1 = new BodyPart();
|
||||||
Header h1 = new Header();
|
Header h1 = new Header();
|
||||||
h1.addField(Field.parse("Content-Type: text/plain"));
|
h1.addField(Fields.contentType("text/plain"));
|
||||||
p1.setHeader(h1);
|
p1.setHeader(h1);
|
||||||
p1.setBody(new StringBody("this stuff"));
|
p1.setBody(new StringBody("this stuff"));
|
||||||
BodyPart p2 = new BodyPart();
|
BodyPart p2 = new BodyPart();
|
||||||
Header h2 = new Header();
|
Header h2 = new Header();
|
||||||
h2.addField(Field.parse("Content-Type: text/plain"));
|
h2.addField(Fields.contentType("text/plain"));
|
||||||
p2.setHeader(h2);
|
p2.setHeader(h2);
|
||||||
p2.setBody(new StringBody("that stuff"));
|
p2.setBody(new StringBody("that stuff"));
|
||||||
BodyPart p3 = new BodyPart();
|
BodyPart p3 = new BodyPart();
|
||||||
Header h3 = new Header();
|
Header h3 = new Header();
|
||||||
h3.addField(Field.parse("Content-Type: text/plain"));
|
h3.addField(Fields.contentType("text/plain"));
|
||||||
p3.setHeader(h3);
|
p3.setHeader(h3);
|
||||||
p3.setBody(new StringBody("all kind of stuff"));
|
p3.setBody(new StringBody("all kind of stuff"));
|
||||||
|
|
||||||
|
@ -127,8 +126,7 @@ public class TestMultipartForm extends TestCase {
|
||||||
public void testMultipartFormStringParts() throws Exception {
|
public void testMultipartFormStringParts() throws Exception {
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
HttpMultipart multipart = new HttpMultipart("form-data");
|
HttpMultipart multipart = new HttpMultipart("form-data");
|
||||||
|
@ -181,8 +179,7 @@ public class TestMultipartForm extends TestCase {
|
||||||
public void testMultipartFormBinaryParts() throws Exception {
|
public void testMultipartFormBinaryParts() throws Exception {
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
File tmpfile = File.createTempFile("tmp", ".bin");
|
File tmpfile = File.createTempFile("tmp", ".bin");
|
||||||
|
@ -236,8 +233,7 @@ public class TestMultipartForm extends TestCase {
|
||||||
public void testMultipartFormBrowserCompatible() throws Exception {
|
public void testMultipartFormBrowserCompatible() throws Exception {
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
File tmpfile = File.createTempFile("tmp", ".bin");
|
File tmpfile = File.createTempFile("tmp", ".bin");
|
||||||
|
@ -311,8 +307,7 @@ public class TestMultipartForm extends TestCase {
|
||||||
|
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; charset=UTF-8; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; charset=UTF-8; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
File tmpfile = File.createTempFile("tmp", ".bin");
|
File tmpfile = File.createTempFile("tmp", ".bin");
|
||||||
|
@ -367,8 +362,7 @@ public class TestMultipartForm extends TestCase {
|
||||||
|
|
||||||
Message message = new Message();
|
Message message = new Message();
|
||||||
Header header = new Header();
|
Header header = new Header();
|
||||||
header.addField(
|
header.addField(Fields.contentType("multipart/form-data; boundary=foo"));
|
||||||
Field.parse("Content-Type: multipart/form-data; boundary=foo"));
|
|
||||||
message.setHeader(header);
|
message.setHeader(header);
|
||||||
|
|
||||||
HttpMultipart multipart = new HttpMultipart("form-data");
|
HttpMultipart multipart = new HttpMultipart("form-data");
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -75,7 +75,7 @@
|
||||||
<httpcore.version>4.0</httpcore.version>
|
<httpcore.version>4.0</httpcore.version>
|
||||||
<commons-logging.version>1.1.1</commons-logging.version>
|
<commons-logging.version>1.1.1</commons-logging.version>
|
||||||
<commons-codec.version>1.3</commons-codec.version>
|
<commons-codec.version>1.3</commons-codec.version>
|
||||||
<mime4j.version>0.5</mime4j.version>
|
<mime4j.version>0.6</mime4j.version>
|
||||||
<junit.version>3.8.2</junit.version>
|
<junit.version>3.8.2</junit.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue