Javascript 联系方式-填写“联系方式”;从「;url在邮件正文中看起来不像url,以避免将msg视为垃圾邮件?

Javascript 联系方式-填写“联系方式”;从「;url在邮件正文中看起来不像url,以避免将msg视为垃圾邮件?,javascript,php,jquery,html,contact-form,Javascript,Php,Jquery,Html,Contact Form,我在我的网站的每一页底部都有一张联系表。通过以下代码发送消息。它工作得很好,但事实上,在邮件正文中,发送邮件的URL显示为“from site:”使邮件每次都指向我的垃圾邮件项目(我知道我可以将其标记为非垃圾邮件等) 有没有办法创建URL(由$\u服务器['HTTP\u REFERER']检索) )在邮件正文中看起来不像url,即输入空格btw www和.com或任何其他解决方案 非常感谢 sendmessage.php: <?php // Email Submit // Note: fi

我在我的网站的每一页底部都有一张联系表。通过以下代码发送消息。它工作得很好,但事实上,在邮件正文中,发送邮件的URL显示为“from site:”使邮件每次都指向我的垃圾邮件项目(我知道我可以将其标记为非垃圾邮件等)

有没有办法创建URL(由
$\u服务器['HTTP\u REFERER']检索)
)在邮件正文中看起来不像url,即输入空格btw www和.com或任何其他解决方案

非常感谢

sendmessage.php:

<?php
// Email Submit
// Note: filter_var() requires PHP >= 5.2.0
if ( isset($_POST['email']) && isset($_POST['name']) && isset($_POST['message']) && filter_var($_POST['email'], FILTER_VALIDATE_EMAIL) ) {

  // detect & prevent header injections
  $test = "/(content-type|bcc:|cc:|to:)/i";
  foreach ( $_POST as $key => $val ) {
    if ( preg_match( $test, $val ) ) {
      exit;
    }
  }

  //send email
 mail( "contact@dfsdfds.com", "New message from: ".$_POST['name'], $_POST['message']."\nFrom site: ". $_SERVER['HTTP_REFERER'], "From:" . $_POST['email'] . "\r\n" . "BCC: dfds@gmail.com" );

}
?>
// Contact Form
$(document).ready(function() {
    $("#contactfrm").submit(function(e) {
        e.preventDefault();
        var name = $("#name").val();
        var email = $("#email").val();
        var message = $("#message").val();
        var dataString = 'name=' + name + '&email=' + email + '&message=' + message;

        function isValidEmail(emailAddress) {
            var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);
            return pattern.test(emailAddress);
        };
        if (isValidEmail(email) && (message.length > 1) && (name.length > 1)) {
            $.ajax({
                type: "POST",
                url: "sendmessage.php",
                data: dataString,
                success: function() {
                    $('input[name="submit"]').hide();
                    $('.error').hide()
                    $('.success').fadeIn(1000);
                }
            });
        } else {
            $('.error').fadeIn(1000);
        }
        return false;
    });
});

也许您需要切断url前面的http://链接,如下所示:

str_replace("http://", "", $_SERVER['HTTP_REFERER'])
如果要在两个对象之间放置空格。com(等)也可以使用str_replace()来实现。
但我认为你不需要在url中添加空格,因为大多数垃圾邮件过滤器都会扫描http://部分以进行链接检测。您的电子邮件被过滤的另一个原因可能是短文本或未知的发送服务器。

只需训练您的垃圾邮件过滤器?如果您不维护多个站点,您也可以剥离整个域,但由于收件人会定期更改,将超出我的控制,因此这不是一个可行的解决方案。但是谢谢你的建议谢谢,我会试试的。我应该把这个放在哪里?(我是PHP的新手)很多thanks@Greg用上面的代码替换
$\u服务器['HTTP\u REFERER']