Workaround receiving multipart for text/html

pull/209/head
M66B 3 years ago
parent f459bf3706
commit 86b2e5347d

@ -3177,21 +3177,38 @@ public class MessageHelper {
result = Helper.readStream((InputStream) content, result = Helper.readStream((InputStream) content,
cs == null ? StandardCharsets.ISO_8859_1 : cs); cs == null ? StandardCharsets.ISO_8859_1 : cs);
} else { } else {
result = null;
StringBuilder m = new StringBuilder(); StringBuilder m = new StringBuilder();
if (content instanceof Multipart) { if (content instanceof Multipart) {
m.append("multipart"); m.append("multipart");
Multipart mp = (Multipart) content; Multipart mp = (Multipart) content;
for (int i = 0; i < mp.getCount(); i++) for (int i = 0; i < mp.getCount(); i++) {
m.append(' ').append(mp.getBodyPart(i).getContentType()); BodyPart bp = mp.getBodyPart(i);
try {
ContentType ct = new ContentType(bp.getContentType());
if (h.contentType.match(ct)) {
String _charset = ct.getParameter("charset");
Charset _cs = (TextUtils.isEmpty(_charset)
? StandardCharsets.ISO_8859_1 :
Charset.forName(_charset));
result = Helper.readStream(bp.getInputStream(), _cs);
}
} catch (Throwable ex) {
Log.w(ex);
}
m.append(' ').append(bp.getContentType());
}
} else } else
m.append(content.getClass().getName()); m.append(content.getClass().getName());
String msg = "Expected " + h.contentType + " got " + m; String msg = "Expected " + h.contentType + " got " + m + " result=" + (result != null);
Log.e(msg); Log.e(msg);
warnings.add(msg); warnings.add(msg);
result = Helper.readStream(h.part.getInputStream(), if (result == null)
cs == null ? StandardCharsets.ISO_8859_1 : cs); result = Helper.readStream(h.part.getInputStream(),
cs == null ? StandardCharsets.ISO_8859_1 : cs);
} }
} catch (DecodingException ex) { } catch (DecodingException ex) {
Log.e(ex); Log.e(ex);

Loading…
Cancel
Save