1

我有一个小型网络应用程序,人们可以在其中通过电子邮件向群组发送消息。由于垃圾邮件,我将不得不进行审批程序。

消息是通过 PHP 发送的。我是怎么做的,所以我必须先接受该消息,然后再将其发送到将其转发给群组的电子邮件?

我的PHP:

<?php 
$errors = '';
$myemail = 'whatever@gmail.com';//<-----Put Your email address here.
if(empty($_POST['name'])  || 
   empty($_POST['email']) || 
   empty($_POST['message']))
{
    $errors .= "\n FEJL: Alle felter skal udfyldes";
}

$name = $_POST['name']; 
$email_address = $_POST['email']; 
$message = $_POST['message']; 
$email_subject = "Form request";
$times = $_POST["timeslots"];

if (!preg_match(
"/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$/i", 
$email_address))
{
    $errors .= "\n FEJL: Ugyldig email adresse";
}
$strTimes = implode($times);
if( empty($errors))
{
$to = $myemail; 
$email_subject = "$message \n ";
$email_body = "\n Code: $strTimes \n Navn: $name \n Email: $email_address \n"; 

$headers = "From: $email_address\n"; 
$headers .= "Reply-To: $email_address";

mail($to,$email_subject,$email_body,$headers);
//redirect to the 'thank you' page
header('Location: thx.html');
} 
?>
4

1 回答 1

0

好的,如果您想使用数据队列,这本身就是一个相当大的项目。

假设您想使用数据库,您将需要了解设置数据库的基础知识、如何使用和设置表等(只要您仍然可以访问数据库)。

这是一些连接代码:

peterabc123更改为您的数据库与之关联的任何用户名和密码。

$con = mysql_connect("localhost","peter","abc123");
if (!$con){
  die('Could not connect: ' . mysql_error());
}
mysql_select_db("my_db");

我将为您提供一些示例代码,用于将行插入数据库、从数据库中选择行、处理该信息以及从数据库中删除行。

好的,让我们从邮件提交开始:

靠近代码底部的这部分是我们需要操作的数据

$to = $myemail; 
$email_subject = "$message \n ";
$email_body = "\n Code: $strTimes \n Navn: $name \n Email: $email_address \n"; 
$headers = "From: $email_address\n"; 
$headers .= "Reply-To: $email_address";

因此,假设您有一个 mysql 数据库连接,并在数据库中设置了一个表,这就是您插入它的方式:(请注意,这是一个基本的插入查询)

$query = "INSERT INTO queuemails (to, subject, body, headers) VALUES ('" . $to . "', '" . $email_subject . "', '" . $email_body . "', '" . $headers . "')";
mysql_query($query);

好的,所以这两行将添加到您设置的变量下方。

然后,您需要提供一个批准页面的方法。

这可以在同一页面上完成,但您必须将您的mail()函数与脚本的其余部分分开。

好的,现在这是一个选择脚本,可以查看您的队列以供批准。请注意,我已在存储您排队的邮件的表中添加了一个自动增量列。这是为了能够更轻松地选择表中的一行,因为它会为该行数据生成一个唯一编号。此列称为mid(代表“邮件标识”)。

好的,这是选择脚本:

$query = "SELECT * FROM queuemail"; //this is only good if you know you wont get millions else you need to limit it
//limited select:
//$query = "SELECT * FROM queuemail LIMIT 0,10"; //selects the first 10
while($m = mysql_fetch_assoc(mysql_query($query))){
  echo $m['to'] . " ";
  echo $m['subject'] . " ";
  echo '<a href=approve.php?mid=' . $m['mid'] . '>Approve</a><br>';
}

然后最后清理,在你使用你的函数之后,应该mail()从你发送的数据库中删除该行。

这是代码(包括$_GET变量,这是一种不安全的方法,但足以显示您将使用的代码)。

mail(); //data can be added either from a new select statement or from POSTING it with the form
$query = "DELETE FROM mailqueue WHERE mid='" . $_GET['mid'] . "'";
mysql_query($query);
echo 'Your mail has been sent and deleted from the queue';

希望这可以帮助。

您可以自动将时间戳添加到数据库中的另一列,以便您可以使用以下内容验证垃圾邮件发布:

if($_SERVER['REQUEST_TIME'] > ($oldtimeofpost + 100)){ //time is in seconds
  //do something
}
else{
  //warning
}
于 2012-09-16T10:54:03.500 回答