0

我有忘记密码表格,用户可以在其中输入有效的电子邮件地址。我向用户发送邮件没有问题,我唯一的问题是我想从数据库(用户名和密码)向用户发送他们的帐户信息,以便他们知道他们的用户名和密码。但似乎我很难在用户的收件箱上显示他们的帐户信息。我是 PHP 新手,如果你能帮助我解决这个问题,那就太好了。

这是我的代码:

编辑:

<?php
if (isset($_POST['submit'])) {
    $email_from = "example@domain.com";
    $datesent = date('D m/d/Y, g:i A');
    $error_message = "";
    $msg = "";
    $subject = "Some text here";


    //some validations here

    $query = "Select * from user_information where EMAIL_ADDRESS = '".$_POST['email']."'";
    $result = mysql_query($query) or die("ERROR: ".mysql_error());
    $check = mysql_num_rows($result);
    if ($check == 0) {
        $row = mysql_fetch_assoc($result);
        $username = $row['USERNAME'];
        $password = $row['PASSWORD'];
        $fname = $row['FIRST_NAME'];
    }
    ob_start(); //Turn on output buffering
?>

    Hi <? php echo $fname; ?>!

        Here is your Account information:

        Username: <? php echo $username; ?>
        Password: <? php echo $password; ?>

    //some text here

<?php
    $message = ob_get_contents();
    ob_get_clean();
    $email_message = "From: ".clean_string($email_from)."\n";
    $email_message. = "Sent: ".clean_string($datesent)."\n";
    $email_message. = "Subject: ".clean_string($subject)."\n";
    $email_message. = "\n".clean_string($message)."\n";
    $headers = 'From: '.$email_from."\r\n";
    $headers. = 'To: '.$email."\r\n";
    $headers. = 'Sent: '.$datesent."\r\n";
    $email_sent = @mail($sendto, $subject, $email_message, $headers);
} ?>
4

4 回答 4

0

改变

if ($check == 0)

if ($check > 0)

注意:不要使用 $_POST , $_GET 变量而不清理它们。如果您不验证和清理 $_POST 和 $_GET 变量,则使用 mysql_query 很容易发生 sql 注入。使用 PHP_PDO

 if (isset($_SESSION['submit'])) {

 if (isset($_POST['submit'])) {
于 2013-02-08T08:33:42.053 回答
0

以下代码对您不起作用:

$check = mysql_num_rows($result);
if($check==0){
    ...
 }

应该:

$check = mysql_num_rows($result);
if($check != false){
    ...
 }

如果没有结果行,您只需设置用户名、密码和 fname

于 2013-02-08T07:56:39.620 回答
0

首先启动会话,然后只有你可以使用会话变量,当从数据库中获取数组时,行数不应该为零,像这样

 if ($check != 0) {
    $row = mysql_fetch_assoc($result);
    $username = $row['USERNAME'];
    $password = $row['PASSWORD'];
    $fname = $row['FIRST_NAME'];
}

并且这段代码也有错误

  ob_start(); //Turn on output buffering
  ?>
  Hi <?php echo $fname; ?>!

    Here is your Account information:

    Username: <?php echo $username; ?>
    Password: <?php echo $password; ?>

//some text here

你没有用过<?php,而是<? php。希望有帮助。

于 2013-02-08T08:43:23.940 回答
0

我假设您发布了整个源文件。如果是这样,您session_start()的文件开头缺少 a 。没有它访问$_SESSION是不可能的。或者,也许您想改用$_POST并编写$_SESSION

于 2013-02-08T08:10:20.323 回答