我的网站上有一个联系表格,实际上有效:D 问题是,电子邮件最终在垃圾邮件文件夹中。我试图用标题部分做一些事情,但似乎没什么用。
任何人都可以帮我吗?
感谢
<?php
ini_set("display_errors", "0");
$post_data = filter_input_array( INPUT_POST, FILTER_SANITIZE_SPECIAL_CHARS );
$name = $post_data["name"];
$email = $post_data["email"];
$phone = $post_data["phone"];
$website = $post_data["website"];
$message = $post_data["message"];
# select data that needs validation
$validate = array(
'required' => array($name,$email,$message),
'validEmail' => array($email),
'validNumber' => array($phone),
'validAlpha' => array($name)
);
$formcontent = "Name: $name \nE-Mail: $email \nPhone: $phone \nWebsite: $website \nMessage: $message \n";
$formcontent = wordwrap($formcontent, 70, "\n", true);
$recipient = "thomas.teilmann@gmail.com";
$subject = "Contact Messenbrink.eu";
/*$mailheader = "From: $email \r\n";**/
$mailheader .= "Reply-To: $name <$email>\r\n";
$mailheader .= "Return-Path: $name <$email>\r\n";
$mailheader .= "Content-Type: text/plain\r\n";
$mailheader .= "Organization: Sender Organization\r\n";
$mailheader .= "MIME-Version: 1.0\r\n";
$mailheader .= "Content-type: text/plain; charset=iso-8859-1\r\n";
$mailheader .= "X-Priority: 3\r\n";
$mailheader .= "X-Mailer: PHP". phpversion() ."\r\n";
$mailheader .= "From: $name <$email>\r\n";
function sendMail() {
global $formcontent, $recipient, $subject, $mailheader;
mail($recipient, $subject, $formcontent, $mailheader);
}
# error messages
$errorsMsgs = array(
'required' => 'Please fill out all required fields.',
'validEmail' => 'is an invalid email address.',
'validNumber' => 'is an invalid number.',
'validAlpha' => 'contains invalid characters. This field only accepts letters and spaces.'
);
$errorMarkup = "<h1>We found a few errors :-(</h1><h2>Please fix these errors and try again</h2><ol>";
$errorMarkupEnd = "</ol>";
$successMarkup = "<h1>Success!</h1><h2>Your form was sent successfully.</h2>";
$backMarkup = "<a href=\"" . $_SERVER['HTTP_REFERER'] . "\">Back to form</a>";
# begin state
$valid = true;
# loop through fields of error types
foreach ($validate as $type => $fields) {
# loop through values of fields to be tested
foreach ($fields as $value) {
# throw error if value is required and not entered
if ($type === 'required' && strlen($value) === 0) {
$errorMarkup .= "<li>$errorsMsgs[$type]</li>";
$valid = false;
break;
}
else if (
$type === 'validEmail' && !filter_var($value, FILTER_VALIDATE_EMAIL) ||
$type === 'validNumber' && !preg_match('/^[0-9 ]+$/', $value) ||
$type === 'validAlpha' && !preg_match('/^[a-zA-Z ]+$/', $value)
) {
if (strlen($value) === 0) {break;} # skip check if value is not entered
$errorMarkup .= "<li>\"$value\" $errorsMsgs[$type]</li>";
$valid = false;
continue;
}
}
}
if ($valid) {
sendMail();
$body = $successMarkup . $backMarkup;
$title = "Form sent";
} else {
$body = $errorMarkup . $errorMarkupEnd . $backMarkup;
$title = "Form errors";
}
# write html ouput
echo "<!DOCTYPE html><head><title>$title</title><style type=\"text/css\">body{margin:100px;font:16px/1.5 sans-serif;color:#111}h1{font-size:32px;margin:0;font-weight:bold}h2{font-size:18px;margin:0 0 20px 0}ol,li{list-style-position:inside;padding-left:0;margin-left:0}</style></head><body>$body</body></html>";
?>
答案 0 :(得分:6)
它与PHP代码无关,但要确保从服务器上托管的域发送电子邮件。这意味着使用你的gmail地址通过PHP发送是一个坏主意。每个离开服务器的电子邮件都需要签名,并且需要有SPF记录
这通常是因为在DNS中尚未设置正确的SPF记录。根据您使用的软件,这可以轻松完成。如果你使用cPanel,那么这几乎是一个两步过程。
有些链接: http://www.emailquestions.com/help-desk/2418-why-do-my-own-emails-go-into-spam.html http://www.google.co.uk/search?sourceid=chrome&ie=UTF-8&q=spf+records http://www.techtalkpoint.com/articles/setting-up-spf-records-in-cpanel-whm-and-namecheap/
答案 1 :(得分:1)
确保消息来源有效。除此之外,你可以用PHP做很多事情。剩下的就是邮件内容,邮件服务器和收件人服务器的垃圾邮件过滤器。
尝试确保标头中的数据与正常消息中通常出现的数据相匹配。例如,您的From和Return-Path域名最好与您发送的服务器匹配。
我注意到你只是使用\n
作为正文中的行分隔符。无论您使用何种操作系统,它都应为\r\n
。
理想情况下,研究RFC 2822。如果您没有时间这样做,请至少将您的标题与您认为有效的其他电子邮件进行比较。在可能的情况下,匹配标题的顺序,包括在相应的位置放置相同数量的空行。
答案 2 :(得分:0)
使用的smtp可能无效。
如果联系表单仅用于向一个邮件文件夹发送电子邮件,我只会在那里设置一条规则,不要将其标记为垃圾邮件。要么那么要么实际验证你的smtp。
答案 3 :(得分:0)
垃圾邮件未经某些设置过滤,您可以通过单词选择以及邮件的外观以及发件人电子邮件地址的知名程度进行过滤。如果你想避免垃圾邮件列表,你必须以一种听起来不垃圾的方式来说明它。
答案 4 :(得分:0)
我的一个建议是将电子邮件的发件人地址作为您用来发送这些邮件的实际邮件帐户的电子邮件地址而不是客户的电子邮件帐户。如果电子邮件来自他们的电子邮件地址而不是来自该域上的服务器,则您的电子邮件提供商可能会认为他们是欺骗性的。
您可以将客户的电子邮件地址放在电子邮件正文中,以便了解其来自何处。
答案 5 :(得分:0)
我遇到了与Gmail类似的问题,我刚刚选择了电子邮件并设置为“非垃圾邮件”现在我的服务器发送的所有电子邮件,当有人使用我网站上的联系表单时最终收件箱文件夹。希望这会有所帮助。