13

I recently learned that webmail clients like Gmail will do alterations on HTML emails, for example adding target="_blank" to <a> tags.

I've also discovered that other alterations happen as well. When I send an HTML email to Gmail (and possibly other web mail clients) from my PHP script, variable values included in the URL of any links are being stripped out. So, for example, this is the value I'm setting in my PHP code:

$mailContent = '<p><a target="_blank" href="https://example.com/confirmation.html?verification=x1x1x1x1x1x1x1x&email=yyyy@email.com">click here to go to the web site and activate your account!</a></p>';

But when the email is received in Gmail, the HTML code comes out like this:

<p><a target="_blank" href="https://example.com/confirmation.html?verification=&email=">click here to go to the web site and activate your account!</a></p>

The values x1x1x1x1x1x1x1x and yyyy@email.com have been stripped out from within the <a> tag.

How do I protect the values of the variables that I want to pass to the URL so that Gmail won't remove them?

mikemaccana
  • 110,530
  • 99
  • 389
  • 494
Questioner
  • 7,133
  • 16
  • 61
  • 94

4 Answers4

3

Click View original/source on the message in Gmail to see if the URLs looks like they should then. If so you know that the problem is how Gmail is formatting the message for your viewing. If it's mutilated even in the source I was wondering if there's anything in your webpage/php/CMS (do you use one) that changes the code.

You should try URL-encoding as @Crisp said. Here's the W3 reference.

PetaspeedBeaver
  • 433
  • 6
  • 17
3

Emailing in html uses Quoted-printable Encoding. The problem with your $mailContent is that the "=" must be represented by =3D

Try adding this: $mailContent = quoted_printable_encode($mailContent);

1

This may not be the perfect answer, but if your application allows for it, I have used URL shorteners a number of times.

http://goo.gl/ is my preferred because the API is super easy to implement and google is very fast. I have a function in a class and I just run my url through it and send the return wherever I need it to be.

NappingRabbit
  • 1,888
  • 1
  • 13
  • 18
0

Another non-perfect answer here but, my problem was that I was including an http url in the html body and apparently is not valid so I changed them to https. This was on a dev environment so no problem on production.

Here is more info about this:

Any URL's in the body of the mail which lead to insecure sites may also need to be removed. Use https://transparencyreport.google.com/safe-browsing/search to validate these links.. All links should be correctly prefixed with "https". https://en.wikipedia.org/wiki/HTTPS Google seem to be rejecting "http". Sometimes, but not always, removing links from any signature can help.

Brugner
  • 527
  • 8
  • 16