Php mail()打破了650个字符长的Url

时间:2012-12-19 14:30:35

标签: php email

我使用php mail函数发送一个包含许多参数的链接。编码后的url长度可以是650或更多字符,因为它保存变量以重新填充表单。

当我点击我的电子邮件中的链接时,它已损坏,因为在URL中的某处插入了一个空格。

继承我的sendMail功能:

    protected function sendEmail($to, $subject, $body) {
        $headers  = 'MIME-Version: 1.0' . "\r\n";
        $headers .= 'Content-type: text/html; charset=iso-8859-1' . '\r\n';
        $headers .= 'From: Sales Order From <sales@imninjas.com>' . '\r\n';
        $headers .= 'X-Mailer: PHP/' . phpversion() . '\r\n';

        $body = '<html><body style="font-size: 10pt; font-family: Arial, Helvetica, sans-serif;">'.$body.'</body></html>';

        return mail($to, $subject, $body, $headers);
    }

这是我用sendMail调用的代码。它的'$ salesUrl = $ this-&gt; getSalesFormUrl();'这是650+字符的网址,充满了编码的参数。

    function emailRep() {
        $params = $this->getParamaterArray();
        $shortUrl = $this->getShortUrl();
        $salesUrl = $this->getSalesFormUrl();

        $mailSubject = "Return to the sales order form for ".$params['clientName']." at ".$params['company'].".";

        $mailBody = "The following information is from an order created on, ".date("l, F j, Y \a\t g:i a").",<br/><br/>";
        $mailBody .= "Customer Contact Information:<br/>";
        $mailBody .= "Name: ".$params['clientName'] params['company']."<br/>";
        $mailBody .= "Shortened Url to Send to the Customer:<br/>";
        $mailBody .= ($shortUrl) ? "<a href='".$shortUrl."'>".$shortUrl."</a><br/><br/>" : "There was an error shortening your url.<br/><br/>";
        $mailBody .= "The URL back to the sales form: For sales rep use only, <strong>Do not give to the customer</strong>.:<br/>";
        $mailBody .= "<span style='font-style: italic;'>Some email clients add special characters to long urls. If the link does not work then copy and paste it into your browser.</span><br/>";
        $mailBody .= "<a href='".$salesUrl."'>".$salesUrl."</a><br/><br/>";

        return ($this->sendEmail($params['repEmail'], $mailSubject, $mailBody));
    }

这是我在电子邮件中收到的URL,您会注意到URL中间的空格'... BhsNKq Jsd_x4 ...'。即使我发送完全相同的网址,每次都会在不同的地方发生这种情况。为了证明这一点,我在emailRep方法中没有空格的情况下对此网址进行了硬编码并多次发送。空间四处移动。

http://example.com/admin/index.php?fdJdj9QgFAbgXzPcNJ3AAdbxgotxdk28cNRMjPESW9yihVbKxHR_vaeU7TSZxqSfHDhPX9Jg-lPneu1H9cFHE7yJxUcdfpto_XNxtv6XHkgw_Vk7oy7aFRdnYzONPDltWxV01Zi23glqnU-z91XnpvrnpvNGSXYo4Q0t6UEKUmUp9Sh28JC7Va01Pmaibcc83M8dpCzzKYn5H_rX_BhsNKq Jsd_x4w7e4zHqputSWdc1Uwzezt2LS5xGQJHKxlF98qbzUZMhauxw_k5ebK8YPwDFr776GEb11WPzGtfhjIFE68zL9H2l3FOCFXea5qkHUmO9pCihThlegDLAHamuIeCmTiXSGv8cm_TorL-6q8NnYuvp6nEfpntthgrvx3enkhWP-FJ0P4vYYAvyJ45pbR9slaw9pbPLsnu4d9nNZSuXJZdll2WXJRc2XKYgu0zRvcwuqBSVwuzylQu4ILugxOJCciG7kF1Qx8vjZl5Y8sIqL59dRu9dfnP5yuXJ5dnl2eXJ3crLl7x8lVeoFJWKe1co_uoK_B1eXZFckV2RXaG-fHvazCuWvGKVV84u23DlzZUrVyZXZldmVyZ3K69c8so57z8

以下是我在通过电子邮件发送之前对url参数进行编码/解码的代码。

class UrlEncoder {
    function compressUrl($url) {
        return rtrim(strtr(base64_encode(gzdeflate($url, 9)), '+/', '-_'), '=');
    }

    function uncompressUrl($url) {
        $startParams = strrpos($url, "?");

        if($startParams) {
            $paramaterString = substr($url, $startParams);
            $host = substr($url, 0, strrpos($url, "?"));
            $uncompressedParamaters = gzinflate(base64_decode(strtr($paramaterString, '-_', '+/')));
            return $host."?".$uncompressedParamaters;
        } else {
            return NULL;
        }
    }
}

如何防止这个空间?我知道我可以用bit.ly这样的东西缩短URL,但它是一个内部工具。我觉得必须有办法阻止插入空间。

3 个答案:

答案 0 :(得分:2)

谁在正确的头脑中使用650个字符长的查询字符串?

我的建议是保存查询字符串服务器端。将它放在一个带有AUTO_INCREMENT字段的数据库中,然后您就可以获得它的ID。然后,您只需将网址发送为http://example.com/?email_key=ID_GOES_HERE,这是一个更短的网址。然后只需从数据库中查找查询字符串。

完成。

答案 1 :(得分:1)

我有你所需要的,http://www.9lessons.info/2009/01/split-url-from-sentence-using-php.html。使用API​​创建tinyurl链接,数据库中没有任何内容:)

答案 2 :(得分:-1)

好的,我有同样的问题。我的解决方案是我自己的链接缩小...在数据库中创建新表,几行,旧脚本中的几行代码,以及重定向的新页面...这是最简短的解释,如果您需要一些帮助,请问: )

编辑:

    function emailRep() {
    $params = $this->getParamaterArray();
    $shortUrl = $this->getShortUrl();
    $salesUrl = $this->getSalesFormUrl();
/***********************************************************************************/   
    $arr = str_split('QWERTYUIOPLKJHGFDSAZXCVBNM123456789qwertyuioplkjhgfdsazxcvbnm'); // get all the characters into an array
    shuffle($arr); // randomize the array
    $arr = array_slice($arr, 0, 6); // get the first six (random) characters out
    $short = implode('', $arr); // smush them back into a string
    mysql_query("INSERT INTO shortlinks VALUES(NULL, '$salesUrl', '$short')");
/*******************************************************************************************/

    $mailSubject = "Return to the sales order form for ".$params['clientName']." at ".$params['company'].".";

    $mailBody = "The following information is from an order created on, ".date("l, F j, Y \a\t g:i a").",<br/><br/>";
    $mailBody .= "Customer Contact Information:<br/>";
    $mailBody .= "Name: ".$params['clientName'] params['company']."<br/>";
    $mailBody .= "Shortened Url to Send to the Customer:<br/>";
    $mailBody .= ($shortUrl) ? "<a href='".$shortUrl."'>".$shortUrl."</a><br/><br/>" : "There was an error shortening your url.<br/><br/>";
    $mailBody .= "The URL back to the sales form: For sales rep use only, <strong>Do not give to the customer</strong>.:<br/>";
    $mailBody .= "<span style='font-style: italic;'>Some email clients add special characters to long urls. If the link does not work then copy and paste it into your browser.</span><br/>";
    $mailBody .= "<a href='".$short."'>".$short."</a><br/><br/>"; // Rename $salesUrl to $short

    return ($this->sendEmail($params['repEmail'], $mailSubject, $mailBody));
}

并重定向页面:     

$token=$_GET['token']; // like http://example.com/out.php?token=ahgByT or make it cleaner with htaccess
$qry=mysql_query("SELECT * FROM links WHERE short='$token'");
$arr=mysql_fetch_array($qry);
$out=$arr['long_link'];
header("Location: ".$out);
?>