我是 PHP 新手,但通常能够解决大多数问题,但这个问题让我受益匪浅。
我正在尝试使用单个提交按钮创建一个时事通讯注册(单个字段)。我可以正常工作,发送一封电子邮件并将表单数据插入我的表格中。但是,我想添加功能以向注册人发送确认电子邮件。我已经进行了广泛的研究,并且我知道这背后的方法,但是我的代码只是没有将数据输入到用于存储确认信息的第二个表中。
我有 2 个表: 表 1 名为“newsletter”的列是:
idmail,emailaddress,datetime,state
idmail
被设定为AUTO_INCREMENT
表 2 中名为“确认”的列是:
idconfirm,emailaddress,confirmkey
这是我的代码(我省略了后面的电子邮件部分,因为一切正常):
//connect to database
include('admin/connection.php');
$email = mysqli_real_escape_string($dbc, $_POST['email']);
//check if value exists in table
$result = mysqli_query($dbc, "SELECT emailaddress FROM newsletter WHERE emailaddress = '$email'");
if (mysqli_num_rows($result)==0) {
//Insert value into database
$query1 = mysqli_query($dbc, "INSERT INTO newsletter(emailaddress, datetime, state) VALUES('$email','$now','0')");
mysqli_query($dbc, $query1);
// Get ID of last record
$id = mysqli_insert_id($dbc);
//Create a random key
$hash = $email.date('mY');
$hash = md5($hash);
//Insert value into database
$query2 = mysqli_query($dbc, "INSERT INTO confrim(idconfirm, emailaddress, confirmkey) VALUES('$id','$email','$hash')");
mysqli_query($dbc, $query2);
当我提交电子邮件地址时,第一个表格已正确填充。
这里的目标是将在第一个 INSERT INTO 查询中创建的自动 ID 放入一个变量中,然后将其添加到名为“idconfim”的第二个表列中。
我试过了:
echo $id;
echo $email;
echo $hash;
并且所有变量都包含正确的信息。
有没有人有任何想法?我已经尝试在这里列出很多东西,但是我已经对此进行了研究,但我只是不知道我哪里出错了。
提前致谢。