Значение PHP $ _POST не появляется в электронной почте для PHPMailer - PullRequest
0 голосов
/ 22 марта 2019

Приветствую всех,

У меня проблема с тем, что значение имени студента и программы не отображается в электронном письме после отправки электронного письма через PHPMailer. Я использую PHP PDO и проверил, что имя и программа учащегося находятся в форме. Другие значения появляются просто отлично в электронном письме, например на изображении ниже: image

Я не уверен, что кавычки создают проблему или что-то еще. Ниже приведен мой код для файла student-meeting-form.php:

<?php
  require ("global-include-student.php");
  require ('PHPMailer/PHPMailerAutoLoad.php');
  require ('PHPMailer/smtp-credentials.php');

  //timezone for Malaysia
  date_default_timezone_set("Asia/Kuala_Lumpur");

  //Condition when the submit button is clicked
  if(isset($_POST["btnSubmit"])){
    try 
    {
      $appointment_date = date('Y-m-d',strtotime($_POST['appointment_date']));
      //$appointment_date = date("Y-m-d H:i:s");

      // Inserting the data into database
      $insert_query = "INSERT INTO appointment (appointment_type, appointment_date, appointment_time, student_id, lecturer_id, field, venue, remarks, appointment_status)
                        VALUES ('".$_POST["appointment_type"]."',
                                '".$appointment_date."',
                                '".$_POST["appointment_time"]."',
                                '".$_POST["student_id"]."',
                                '".$_POST["lecturer_id"]."',
                                '".$_POST["field_id"]."',
                                '".$_POST["venue"]."',                 
                                '".$_POST["remarks"]."',
                                '".$_POST["appointment_status"]."'                                       
                                )";

      //PHPMailer set up
      $field_name = $_POST['field_name'];
      $lect_name = $_POST['lect_name'];
      $lect_email = $_POST['lect_email'];
      $student_name = $_POST['student_name'];
      $programme = $_POST['programme'];

      $output='<strong>Greetings from STULEC,</strong> <br/>
              <p>There is an appointment request from ' . $student_name . ' who is in the ' . $programme . ' programme.</p> 
              The appointment details are such as below: <br/>
                <ul>
                  <li>Appointment Type: '. $_POST['appointment_type'] .'</li>
                  <li>Appoinment Date: '. $_POST['appointment_date'] .'</li>
                  <li>Appointment Time: '. $_POST['appointment_time'] . '</li>
                  <li>Venue: '. $_POST['venue'] .' </li>
                  <li>Course Field: '. $_POST['field_name'] .' </li>
                  <li>Remarks: '. $_POST['remarks'] . '</li>
                </ul>
              </p>
              <p>Please approve the appointment request by logging into STULEC. Thank you.';

      $mail = new PHPMailer;
      $mail->isSMTP();                                // Set mailer to use SMTP
      $mail->Host = 'smtp.gmail.com';             // Specify main and backup SMTP servers
      $mail->SMTPAuth = true;                   // Enable SMTP authentication
      $mail->Username = EMAIL;              // SMTP username
      $mail->Password = PASS;               // SMTP password
      $mail->SMTPSecure = 'tls';                    // Enable TLS encryption, `ssl` also accepted
      $mail->Port = 587;                        // TCP port to connect to

      $mail->setFrom('stulec@edu.my', 'STULEC');  //From sender
      $mail->addAddress($lect_email, $lect_name);  // Add a recipient
      $mail->isHTML(true);                    // Set email format to HTML

      $mail->Subject = 'STULEC | Appointment Request from Student';
      $mail->Body    =  $output;
      $mail->CharSet = 'utf-8';
      $mail->ContentType = 'text/html';                          

      if (($db->query($insert_query)) && $mail->send())
      {
        echo "<script type= 'text/javascript'>alert('An appointment has been made with the lecturer. Please wait until the lecturer responds to your request.');";
        echo 'window.location= "student-view-pending-appointment.php"';
        echo "</script>";
      }                                          
      else
      {
        echo "<script type= 'text/javascript'>alert('Error: The appoinment cannot be made!');";
        echo 'window.location= "student-appointment-form.php"';
        echo "</script>";
      }
    }
    catch(PDOException $e)
    {
      echo $e->getMessage();
    }
  }

?>   

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <title>STULEC | Appointment Form</title>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">

 <!--Include header-->
 <?php include 'include/header.php' ?>

  <!--Include sidebar-->
  <?php include 'include/sidebar.php' ?>

  <!-- Content Wrapper. Contains page content -->
  <div class="content-wrapper">
    <!-- Content Header (Page header) -->
    <section class="content-header">
      <h1 align='center'>
        <u>Appointment Form</u>
      </h1>
    </section>

    <!-- Main content -->
    <section class="content">
      <div class="box box-default">
        <div class="box-body">
          <div class="row">
            <div class="col-md-12">
                  <!-- form start -->
                  <form class="form-horizontal" action="" method="POST">
                  <?php
                     //select student details from the database
                    $sql = "SELECT username, name, role, department, programme, profile_pic, programme_name FROM users 
                    LEFT JOIN programme AS programme ON programme.programme_id = users.programme
                    WHERE user_id = :user_id";        

                    $stmt = $db->prepare($sql);
                    if ($stmt->execute(array('user_id' => $_SESSION['user_id'])))
                    {
                      while($row = $stmt->fetch()) 
                      {
                      //fetch the rows
                        $username = $row['username'];
                        $name = $row['name'];
                        $programme = $row['programme_name'];

                        echo " 
                        <!--Name-->
                        <div class='form-group'>
                          <label for='Name' class='col-sm-2 control-label'>Name</label>
                          <div class='col-sm-10'>
                            <input type='text' class='form-control' name='student_name' id='student_name' value='". $row['name']."' disabled>
                            <input type='hidden' class='form-control' name='student_id' id='student_id' value=" . $row['username'] ." />
                          </div>
                        </div>

                        <!--Programme-->
                        <div class='form-group'>
                          <label for='Programme' class='col-sm-2 control-label'>Programme</label>
                          <div class='col-sm-10'>
                            <input type='text' class='form-control' name='programme' id='programme' value=" . $row['programme_name'] ." disabled>
                          </div>
                        </div>
                        ";
                      }
                    }
                  ?>

                    <!--Consultation Type-->
                    <div class='form-group'>
                      <label for='ConsultationType' class='col-sm-2 control-label'>Consultation Type</label>
                      <div class='col-sm-10'>
                        <select class='form-control' name='appointment_type'>
                          <option selected='selected' name='assignment_discussion' value='Assignment Discussion'>Assignment Discussion</option>
                          <option name='advisory_session' value='Advisory Session'>Advisory Session</option>
                          <option name='fyp_discuss' value='Final Year Project Discussion'>Final Year Project Discussion</option>
                        </select>
                      </div>
                    </div>

                    <!--Field name-->
                    <div class='form-group'>
                      <label for='Course' class='col-sm-2 control-label'>Course Field</label>
                      <div class='col-sm-10'>
                        <select class='form-control' name='field_id' id='field_id' required>  
                          <option value=''>Please select a course field</option>         
                          <?php
                            //Display field name
                            $select_field_query = "SELECT field_id, field_name FROM course_field 
                                                    LEFT JOIN field_programme ON field_programme.field = course_field.field_id
                                                    LEFT JOIN users ON users.programme = field_programme.programme
                                                    LEFT JOIN programme ON programme.programme_id = field_programme.programme
                                                    WHERE field_programme.programme = :programme AND users.username = :student";
                            $field_statement = $db->prepare($select_field_query);
                            $field_statement->bindParam(':programme', $_SESSION['programme']);
                            $field_statement->bindParam(':student', $_SESSION['username']);
                            $field_statement->execute();

                            while ($row = $field_statement->fetch(PDO::FETCH_ASSOC)) 
                            {
                              echo 
                              "<option value='" . $row['field_id'] . "'>" . $row['field_name'] . "</option>";
                            }
                          ?>   
                        </select>
                      </div>
                    </div>

                    <!--Hidden course field_name-->
                    <input type='hidden' id='field_name' name='field_name'>

                    <!--Lecturer name selection-->
                    <div class='form-group'>
                      <label for='Lecturer' class='col-sm-2 control-label'>Lecturer</label>
                      <div class='col-sm-10'>
                        <select class='form-control' name='lecturer_id' id='lecturer_id'>
                            <option>-</option>
                        </select>
                      </div>  
                    </div>

                    <!--Hidden lecturer email-->
                    <input type='hidden' id='lect_email' name='lect_email'>

                    <!--Hidden lecturer name-->
                    <input type='hidden' id='lect_name' name='lect_name'>        

                    <!-- Date -->
                    <div class='form-group'>
                      <label for='Date' class='col-sm-2 control-label'>Date</label>
                      <div class='col-sm-4'>
                        <div class='input-group date'>
                          <input type='text' class='form-control pull-right' name='appointment_date' id='datepicker' required>
                          <div class='input-group-addon'>
                            <i class='fa fa-calendar'></i>
                          </div>
                        </div><!-- /.input group -->
                      </div><!-- /.form group -->    
                    </div>

                    <!-- Time -->
                    <div class='form-group'>
                      <label for='Time' class='col-sm-2 control-label'>Time</label>
                      <div class='col-sm-4'>
                        <div class='input-group time'>
                          <input type='text' class='form-control timepicker' name='appointment_time' id='timepicker' required>
                          <div class='input-group-addon'>
                            <i class='fa fa-clock-o'></i>
                          </div>
                        </div><!-- /.input group -->
                      </div>
                    </div><!-- /.form group -->

                    <!--Venue-->
                    <div class='form-group'>
                      <label for='Venue' class='col-sm-2 control-label'>Venue</label>
                      <div class='col-sm-10'>
                        <select class='form-control' name='venue'>
                          <option selected='selected' name='in_front_dpmt' value='In front of department'>In front of department</option>
                          <option name='library' value='Library'>Library</option>
                          <option name='consultation_room' value='Consultation Room'>Consultation Room</option>
                        </select>
                      </div>
                    </div>

                    <!--Remarks-->
                    <div class='form-group'>
                      <label for='Remarks' class='col-sm-2 control-label'>Remarks</label>
                      <div class='col-sm-10'>
                        <input type='text' class='form-control' name='remarks' id='remarks' placeholder='Eg: Related to the Local Area Network question' required>
                      </div>
                    </div> 

                    <!--Hidden Appointment Status which is set as Pending when form is submitted-->
                    <input type="hidden" value="Pending" name="appointment_status">

                    <!--Submit button-->
                    <div class="box-footer">
                      <button type="submit" class="btn btn-success pull-right" name="btnSubmit" id="btnSubmit">Submit</button>
                    </div> 
                  </form>
                </div><!-- /.box -->
            </div><!-- /.col -->
            </div><!-- /.col -->
          </div><!-- /.row -->
        </div><!-- /.box-body -->
      </div><!-- /.box -->

</div><!-- ./wrapper -->


<!-- Page script -->
<script>
  $(function () 
  {
    //Change lecturer when different course field is selected
    $("#field_id").change(function () {
      if ($('#field_id option:selected').val() != "")
      {
        $.ajax({
            type: 'POST',
            url: 'ajax-field-lecturer.php',
            data: { 'field_id' : $('#field_id option:selected').val() },
            success: function(data) {
                $('#lecturer_id').empty();
                var lect = JSON.parse(data);
                $.each(lect, function( index, lectObj ) 
                {
                  if (index == 0)
                  {
                    $('#lect_email').val(lectObj.email);
                    $('#lect_name').val(lectObj.name);
                    $('#field_name').val(lectObj.field_name);
                  }
                    $('#lecturer_id').append("<option value='"+lectObj.username+"'>"+lectObj.name+"</option>");
                });
            },
            error: function(data) {
                alert(data);
            }
        });
      }
      else
      {
        $('#lecturer_id').empty();
      }  
    });

    //Change lecturer email when different the lecturer is selected
    $("#lecturer_id").change(function () {
      if ($('#lecturer_id option:selected').val() != "")
      {
        $.ajax({
            type: 'POST',
            url: 'ajax-email-lecturer.php',
            data: { 'lecturer_id' : $('#lecturer_id option:selected').val() },
            success: function(data) {
                //alert(data);
                $('#lect_email').empty();

                var lect = JSON.parse(data);
                $('#lect_email').val(lect[0].email);
            },
            error: function(data) {
                alert(data);
            }
        });
      }
      else
      {
        $('#lect_email').empty();
      }  
    });

    //Show lecturer name
    $("#lecturer_id").change(function () {
      if ($('#lecturer_id option:selected').val() != "")
      {
        $.ajax({
            type: 'POST',
            url: 'ajax-name-lecturer.php',
            data: { 'lecturer_id' : $('#lecturer_id option:selected').val() },
            success: function(data) {
                //alert(data);
                $('#lect_name').empty();

                var lect = JSON.parse(data);
                $('#lect_name').val(lect[0].name);
            },
            error: function(data) {
                alert(data);
            }
        });
      }
      else
      {
        $('#lect_name').empty();
      }  
    });

    //Show course field name
    $("#field_id").change(function () {
      if ($('#field_id option:selected').val() != "")
      {
        $.ajax({
            type: 'POST',
            url: 'ajax-field-name.php',
            data: { 'field_id' : $('#field_id option:selected').val() },
            success: function(data) {
                //alert(data);
                $('#field_name').empty();

                var lect = JSON.parse(data);
                $('#field_name').val(lect[0].field_name);
            },
            error: function(data) {
                alert(data);
            }
        });
      }
      else
      {
        $('#field_name').empty();
      }  
    });

    //Date picker
    $( "#datepicker" ).datepicker({
    dateFormat: "yyyy-MM-dd"
    });

    //Timepicker
    $('.timepicker').timepicker({
      showInputs: false
    })
  })
</script>
</body>
</html>

Пожалуйста, объясните мне, как решить эту проблему. Спасибо.

1 Ответ

3 голосов
/ 22 марта 2019

В вашей форме ваши student_name и programme поля disabled и не опубликованы. Подумайте об использовании hidden входных данных для публикации значений или измените disable на readonly (не уверен, что последний работает, хотя).

...