ZF-264: Quoted Printable Problems

Issue Type: Bug Created: 2006-07-17T11:27:19.000+0000 Last Updated: 2009-02-12T15:35:11.000+0000 Status: Resolved Fix version(s): - 0.9.2 (06/Apr/07)

  • 1.7.5 (16/Feb/09)

Reporter: Kevin McArthur (kevin) Assignee: Benjamin Eberlei (beberlei) Tags: - Zend_Mime

Related issues: - ZF-1688



Problem 1:

First the rfc states lines have a 76 character (encoded form) hard limit in length. This limit while implemented isnt working quite right. Lines regularily reach 80 chars.

This is due to the tack on of the =20 after the split (see second line) the other lines I think are over by one character but I might just be counting wrong.


man",Times,serif; color: #666; margin-bottom: 5px; line-height: 1.5em; borde= r-bottom: 1px solid #ccc; font-size: 20px; margin-top: 10px; }=0A=09=09h2 {=20= font-size: 14px; color: #666; margin-bottom: 10px; line-height: 1.5em; borde=

Problem 2:

= line endings, aka soft breaks.

Im not sure why, and I dont see in the RFC any explanation but my email clients all have a problem with the following line ending scenario

An encoded entity, followed by a softbreak, immediately followed by another encoded identity


=0A=09=09=09=09=09Phone #: 1
=0A=09=09=09=09=09=09=09=09= =09

=0A=09=09=09=0A=09=09=09=0A=09=09=09=09= This will always result in an = sign being printed on the line below Phone #:1. My intutition is that if the following line begins with an identity, the soft-break = should be omitted, though I cant find anything in the rfc to back this up.


Posted by Kevin McArthur (kevin) on 2006-07-20T11:07:13.000+0000


Chanign the line ending from \r\n to \n by itself resolves this error in a functional way. The new resultant output however, appears RFC invalid.

A temporary fix is

Index: library/Zend/Mime.php

--- library/Zend/Mime.php (revision 918) +++ library/Zend/Mime.php (working copy) @@ -39,7 +39,7 @@ const DISPOSITION_ATTACHMENT = 'attachment'; const DISPOSITION_INLINE = 'inline'; const LINELENGTH = 74; - const LINEEND = "\r\n"; + const LINEEND = "\n"; const MULTIPART_ALTERNATIVE = 'multipart/alternative'; const MULTIPART_MIXED = 'multipart/mixed'; const MULTIPART_RELATED = 'multipart/related';

Posted by Daniel Schregenberger (npfdd) on 2006-09-03T11:03:23.000+0000

I seem to have similar problems.

GMX mangles mails sent with Zend/Mail. It does convert the softbreaks to real line breaks. Also when using POP3. I suspect their spamfilter but I don't know what to do about it. Having 8-bit encoding would probably fix this. I'm not sure about workarounds.

Posted by Alexei Yuzhakov (ayuzhakov) on 2006-11-14T04:55:16.000+0000

We use Zend Framework and especially Zend_Mail in our product SiteBuilder - We have responce about this bug from our customers. LINEEND = "\r\n" really doesn't work correct all the time (many reports about using this with qmail installations). But using LINEEND = "\n" solves this problem. We had tested with many intallations of sendmail, postfix and qmail MTAs and LINEEND = "\n" always worked correctly. So I suggest to apply fix into SVN.

Posted by Bill Karwin (bkarwin) on 2006-11-28T17:56:51.000+0000

Scheduling for release 0.7.0.

Posted by Eric Coleman (eric) on 2006-12-15T13:16:31.000+0000

It possible to get the spam cleared out of here ;)

And maybe even get the scheduled release bumped up ;)

Posted by Garth Gillespie (garth.gillespie) on 2007-01-30T17:52:20.000+0000

I saw that this wasn't addressed in the 0.7.0 release.

I realize that \r\n is the RFC but something in how it is implemented in ZF does not make several MTA's happy.

Here are problem mail servers/clients you can use to test.

With \r\n in Zend/Mime.php send a multi-part html/text email using quoted-printable.

Use QPopper on the local machine to retrieve mail to any mail client (i.e. Outlook) - HTML is shown badly broken

Send to a gmail account - html will be broken.

Send to Exchange 5, Lotus Groupware (just about any version) - html broken.

gmail is probably the easiest test for this project to use.

Posted by Garth Gillespie (garth.gillespie) on 2007-03-19T13:16:27.000+0000

What is the deal with this getting continually pushed back. Do the developers disagree with the proposed fix?

Posted by Garth Gillespie (garth.gillespie) on 2007-03-30T13:11:59.000+0000


Can you give an update on this issue please?

Posted by Matthew Weier O'Phinney (matthew) on 2007-04-02T12:24:15.000+0000

I've patched the Zend/Mime.php file in revision 4310. Please update from SVN and test. It still passes all unit tests, but I want to be sure that it resolves the problems reported by each of you.

Garth -- the reason for the pushback has been a simple lack of time to address all my areas of responsibility in the framework. I apologize -- it's indeed a trivial fix, but it's been entirely off my radar.

Posted by Garth Gillespie (garth.gillespie) on 2007-04-02T19:01:39.000+0000

I checked the SVN history and see that all you changed was the LINEEND line - that is what I have always changed - so this change will work with the mailers I outlined above - including gmail.


Posted by Matthew Weier O'Phinney (matthew) on 2007-04-02T20:51:54.000+0000

Resolving per Garth Gillespie

Posted by Kevin McArthur (kevin) on 2008-07-16T10:10:57.000+0000

Changing LINEEND does not resolve this bug. Its a tempfix at best. The larger issue here is RFC invalid quoted printable support.

Posted by Kevin McArthur (kevin) on 2008-07-16T10:11:38.000+0000

Reopening as this issue is not resolved.

Posted by Benjamin Eberlei (beberlei) on 2009-01-18T10:27:11.000+0000

Issue resolved by adding a new function Zend_Mime::encodeQuotedPrintableHeader which enforces RFC

Posted by old of Satoru Yoshida ( on 2009-01-30T21:10:21.000+0000

I copied to 1.7 branch at SVN r13886.

Posted by old of Satoru Yoshida ( on 2009-02-02T18:21:50.000+0000

Sorry, not in 1.7.4. I think it will be released in next minor or major.

Posted by Benjamin Eberlei (beberlei) on 2009-02-12T15:35:11.000+0000

This will be in 1.7.5

Have you found an issue?

See the Overview section for more details.


© 2006-2016 by Zend, a Rogue Wave Company. Made with by awesome contributors.

This website is built using zend-expressive and it runs on PHP 7.